黑马程序员——JAVA高新技术总结(一)

来源:互联网 发布:淘宝访客下降怎么解决 编辑:程序博客网 时间:2024/05/22 14:24
------- android培训、java培训、期待与您交流! ----------

静态导入

   import语句可以导入一个类或某个包中的所有类
   import static语句导入一个类中的某个静态方法或所有静态方法
语法举例: 
   import static java.lang.Math.sin;
   import static java.lang.Math.*; 


可变参数

     Java1.5增加了新特性:可变参数:适用于参数个数不确定,类型确定的情况,java把可变参数当做数组理。注意:可变参数必须位于最后一项。当可变参数个数多余一个时,必将有一个不是最后一项,所以只支持有一个可变参数。因为参数个数不定,所以当其后边还有相同类型参数时,java无法区分传入的参数属于前一个可变参数还是后边的参数,所以只能让可变参数位于最后一项。

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


增强for循环

          for/in循环就是JDK5.0中所谓的增强For循环,它能对数组和集合进行遍历,使用它会使用你的代码短小而精炼的多
语法:for ( type 变量名:集合变量名 )  { … } 
注意事项:迭代变量必须在( )中定义!集合变量可以是数组或实现了Iterable接口的集合类
举例: 
public static int add(int x,int ...args) {
int sum = x;
for(int arg:args) {
sum += arg;}

 return sum;}


自动拆箱装箱

      在JDK1.5之前,我们要实现基本类型和包装类之间的转换,大多是通过包装类提供的方法,Integer i =Integer.valueOf(5)或者int j = i.intValue()来做互相转换的。JDK1.5之后,编译器会在我们做赋值操作的时候帮我们自动完成基本类型和包装类之间的相互转换。包装类是类,是对象,而基本类型是有值的“变量”,再细化一点,就是包装类的实例(对象)创建在堆上,而基本类型创建在栈上,这是JAVA为了程序的速度考虑做出的优化,那么既然是创建在栈上,所以基本类型都有大小的规定(每种基本类型所占的字节是一定的)。


枚举

     枚举就是要让某个类型的变量的取值只能为若干个固定值中的一个,否则,编译器就会报错。枚举可以让编译器在编译时就可以控制源程序中填写的非法值,普通变量的方式在开发阶段无法实现这一目标。枚举就相当于一个类,其中也可以定义构造方法、成员变量、普通方法和抽象方法。枚举元素必须位于枚举体中的最开始部分,枚举元素列表的后要有分号与其他成员分隔。把枚举中的成员方法或变量等放在枚举元素的前面,编译器报告错误。

注意:枚举只有一个成员时,就可以作为一种单例的实现方式。


反射

    一个类被类加载器加载到内存中,占用一片存储空间,这个空间里面的内容就是类的字节码,不同的类的字节码是不同的,所以它们在内存中的内容是不同的,这一个个的空间可分别用一个个的对象来表示,这些对象显然具有相同的类型。

基本的 Java 类型(booleanbytecharshortintlongfloat 和 double)和关键字 void 也表示为 Class对象。

    反射就是把Java类中的各种成分映射成相应的java类。

1、Constructor类代表某个类中的一个构造方法
得到某个类所有的构造方法:Constructor [] constructors= Class.forName("java.lang.String").getConstructors();

得到某一个构造方法:  Constructor constructor =Class.forName(“java.lang.String”).getConstructor(StringBuffer.class);

创建实例对象:通常方式:String str = new String(new StringBuffer("abc"));

              反射方式: String str = (String)constructor.newInstance(new StringBuffer("abc"));

2、Method类代表某个类中的一个成员方法

得到类中的某一个方法: Method charAt = Class.forName("java.lang.String").getMethod("charAt", int.class);
调用方法:
        通常方式:System.out.println(str.charAt(1));
        反射方式: System.out.println(charAt.invoke(str, 1)); 
如果传递给Method对象的invoke()方法的第一个参数为null,说明该Method对象对应的是一个静态方法!
jdk1.4和jdk1.5的invoke方法的区别:
   Jdk1.5:public Object invoke(Object obj,Object... args)
   Jdk1.4:public Object invoke(Object obj,Object[] args),即按jdk1.4的语法,需要将一个数组作为参数传递给invoke方法时,数组中的每个元素分别对应被调用方法中的一个参数,所以,调用charAt方法的代码也可以用Jdk1.4改写为 charAt.invoke(“str”, new Object[]{1})形式。

3、数组的反射

具有相同维数和元素类型的数组属于同一个类型,即具有相同的Class实例对象。代表数组的Class实例对象的getSuperClass()方法返回的父类为Object类对应的Class。基本类型的一维数组可以被当作Object类型使用,不能当作Object[]类型使用;非基本类型的一维数组,既可以当做Object类型使用,又可以当做Object[]类型使用。Array工具类用于完成对数组的反射操作。

4、作用

    Java反射机制主要提供了以下功能:在运行时判定任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判定任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。


0 0
原创粉丝点击