黑马程序员——学习日志12高新技术(上)

------- android培训java培训、期待与您交流! ---------- 



1、静态导入

    静态导入可以导入静态方法,这样就不必写类名而可以直接省略类名调用静态方法了。

      好处:使用静态导入可以简化程序对类静态属性和方法的调用,并且简化了程序代码的书写。

      弊端:虽然JDK中出现了这个新特性,但是如果我们在自己的类中定义 了一个方法,与导入的类中的静态方法一样。 那Java虚拟机怎么知道用的是那个类的方法呢?所以虽然出现了这个新特性,但是建议还是别使用。

2、可变参数

      可变参数的出现解决了一个方法接受的参数个数不固定的问题。如果使用重载的方式解决需要写多个重载的方法,可是代码过于繁杂,而使用可变参数就可以避免这种情况。

      注意:可变参数只能出现在参数列表的最后;可变参数只能在参数中只能有一个;可变参数位于变量类型和变量名之间,前后有无空格都可以;调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中以数组的形式访问可变参数。

3、增强for循环

      格式:for(修饰符 变量类型 变量  :需迭代的数组或集合){}。

4、自动拆箱与装箱与享元设计模式

      JDK 1.5的语法允许开发人员把一个基本数据类型直接赋给对应的包装类变量, 或者赋给Object 类型的变量,这个过程称之为自动装箱。 自动拆箱与自动装箱与之相反,即把包装类对象直接赋给一个对应的基本类型变量。

对于这些基本数据整数要装箱成Integer对象的时候,如果这个数据在1字节(-128~ 127)之内的数字,就缓存在byte常量池,下次再用到的时候,先看池子里面有没有,如果有直接从池子里面拿来用。这样节省了内存空间。 这是一种设计模式叫做享元模式。(flyweight)

享元模式: 就是有很多个小的对象,他们有很多属性相同,把他们封装成一个对象,那些不同的属性,把它们变为方法的参数,称之为外部状态,那些相同的属性的称之为这个对象的内部状态。

5、枚举

      枚举就是要让某个类型的变量的取值只能为若干个固定值中的一个,否则,编译器就会报错。枚举可以让编译器在编译时就可以控制源程序中填写的非法值,普通变量的方式在开发阶段无法实现这一目标。

普通类实现枚举(以星期为例):私有的构造方法;每个元素分别用一个公有的静态成员变量表示;可以有若干公有方法或抽象方法。采用抽象方法定义nextDay就将大量的if.else语句转移成了一个个独立的类。

常用方法:name();ordinal();valueOf(String name);values() 。

总结:枚举是一种特殊的类,其中的每个元素都是该类的一个实例对象,其中也可以定义构造方法、成员变量、普通方法和抽象方法。枚举只有一个成员时,就可以作为一种单例的实现方式。

6、反射

      java程序中的各个java类属于同一类事物,描述这类事物的java类就是Class。只要在Java源程序出现的类型,都有各自的Class实例对象。反射就是把Java类中的各种成分映射相成Java类。

      如何得到一个类的字节码:类名.class,例如,System.class;对象.getClass(),例如,newDate.getClass();Class.forName(“类名”),例如,Class.forName(“java.util.Date”).

      构造方法的反射:Constructor类的实例对象代表类的一个构造方法。 反射公共,私有和保护的构造方法:反射公共的需要的方法是:getConstructor(); 反射私有的需要的方法是:getDeclaredConstructor(); Constructor对象代表一个构造方法,Constructor对象有的方法:得到构造方法名字,得到所属于的类,产生实例对象。得到某个类空参数构造方法,例:Constructor constructor= Class.forName("java.lang.String").getConstructor();得到某个类所有的构造方法,例:Constructor []constructors= Class.forName("java.lang.String").getConstructors();得到某一个带参数的构造方法,例:Constructor constructor=Class.forName("java.lang.String").getConstructor(StringBuffer.class);

      成员变量的反射:Field类代表反射某个类中的一个成员变量。和构造方法类似,取私有成员变量时需要使用setAccessible(true)方法实现。

      方法的反射:Method代表某个类中的一个成员方法,调用方法用invoke(),invoke()的第一个参数为空代表方法是静态的。mainMethod.invoke(null,newString[]{“xxx”}),这个方法有错误,jdk1.5要兼容1.4的语法,把数组中的每一个元素看做一个参数,因此会出问题,可以通过new Object[]{new String[]{“xxx”}}或者(Object)new String[]{“xxx”}两种方式解决。

      数组的反射:具有相同参数类型和相同维度的数组具有相同的Class实例对象 。基本类型的一维数组可以被当作Object类型使用,不能当作Object[]类型使用;非基本类型的一维数组,既可以当做Object类型使用,又可以当做Object[]类型使用。

      Hashcode和内存泄露:当一个对象被存储进HashSet集合中以后,就不能修改这个对象中的那些参与计算哈希值的字段了,否则,对象修改后的哈希值与最初存储进HashSet集合中时的哈希值就不同了,在这种情况下,即使在contains方法使用该对象的当前引用作为的参数去HashSet集合中检索对象,也将返回找不到对象的结果,这也会导致无法从HashSet集合中单独删除当前对象,从而造成内存泄露。

7、内省和JavaBean

      JavaBean是一种特殊的Java类,主要用于传递数据信息,这种Java类中的方法主要用于访问私有的字段,且方法名符合某种命名规则。一个类被当作JavaBean使用时,JavaBean的属性是根据方法名推断出来的,它根本看不到Java类内部的成员变量。需要用的几个类PropertyDescriptor、Method、IntroSpector。

8、注解

      注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。

      简单的几个注解:SuppressWarnings、Deprecated、Override。

@Retention元注解的其三种取值:RetetionPolicy.SOURCE、RetetionPolicy.CLASS、RetetionPolicy.RUNTIME;分别对应:java源文件-->class文件-->内存中的字节码。

@Target元注解,默认为任何元素,用数组方式设置值。

注解的缺省属性:default后面添加。

注解的属性类型包括:基本数据类型,String,Class,枚举,其他注解,以及这些类型的数组。

 

 



------- android培训java培训、期待与您交流! ----------

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值