您的位置:首页 > 编程语言 > Java开发

高兴技术 JDK1.5新特性(六)

2013-09-18 14:21 190 查看

JDK1.5新特性
一:静态导入

l
Import语句可以导入一个类或某个包中的所有类。

l
Import static语句导入一个类中的某个静态方法或所有静态方法。

示例:

<pre class="java" name="code">[java] view plaincopyprint?
01.import static java.lang.Math.max;// 静态导入Math类下的静态max方法
02.
03.//import static java.lang.Math.*;// 静态导入Math类下所有的静态方法
04.
05.public class StaticImport {
06.        public static void main(String[] args) {
07.            System.out.println(max(3, 6));
08.            System.out.println(Math.abs(3 - 6));
09.        }
10.}



二:可变参数

l Overload重载

l Override重写

l 只能出现在参数列表的最后

l ...位于参数类型和参数名之间,前后有无空格都可以。

l 调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中以数组的形式访问可变参数。

示例:

[java] view plaincopyprint?
01.public class VariableParameter {
02.        public static void main(String[] args) {
03.            System.out.println(add(1, 2, 2, 2, 2));
04.        }
05.
06.        public static int add(int x, int... args) {
07.            int sum = 0;
08.            sum += x;
09.            for (int i = 0; i < args.length; i++) {
10.                sum += args[i];
11.            }
12.            return sum;
13.        }
14.}


三:增強For循环

语法:for(type
变量名:集合变量名){



}

注意:1.迭代变量必须在()中定义。

2.集合变量可以是数组或实现了Iterable接口的集合类。

示例:

<span style="font-size:14px;">[java] view plaincopyprint?
01.public static int add(int x, int... args) {
02.            int sum = 0;
03.            sum += x;
04.            for (int i : args) {
05.                sum += i;
06.            }
07.            return sum;
08.        }
</span>

l 为什么要有枚举?

1. 问题:要定义星期几或性别的变量,该怎么定义?假设用1-7分别表示星期一到星期日,但有人可能会写成int weekday = 0;

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

l 用普通类如何实现枚举功能,定义一个Weekday的类用来模拟枚举功能。

1. 私有的构造方法。

2. 每个元素分别用一个公有的静态成员变量表示。

3. 可以有若干公有方法或抽象方法,例如,要提供nextDay方法必须是抽象的。

l 在枚举类型中,一般的定义形式如下:

Enum 枚举名{枚举值表}

泛型

为什么会出现泛型?

因为集合存放的数据类型不固定,故往集合里面存放元素时,存在安全隐患,
如果在定义集合时,可以想定义数组一样指定数据类型,那么就可以解决该类安全问题。
JDK1.5后出现了泛型,用于解决集合框架的安全问题。
泛型是一个类型安全机制。
泛型定义格式:通过<>来定义要操作的引用数据类型
ArrayList<String> al = new ArrayList<String>;

泛型的好处:

将运行时期出现的ClassCastException(类型转换异常)问题转移到编译时期。

避免了强制转换的麻烦。

什么时候定义泛型?

泛型在集合框架中很常见,只要见到<>就要定义泛型。其实<>就是用来接收类型的。

当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可。

泛型的形式:

l 泛型类:即自定义泛型类

A:当类中要操作的引用数据类型不确定时,早起定义Object来完成扩展,现在定义泛型来完成
B:局限性:泛型类定义的泛型,在整个类中有效,如果该泛型类的方法被调用,当泛型类的对象明确要操作的类型后,所有要操作的类型就被固定。
l 泛型方法:泛型放在返回值前面,修饰符的后面

A:为了避免泛型类的局限性,让不同方法可以操作不同的类型,而且类型还不确定,则可以将泛型定义在方法上。
B:特殊之处:静态方法不可以反问类上定义的泛型。
如果静态方法操作的应用数据类型不确定,可以讲泛型定义在静态方法上。
l 泛型接口:
当泛型定义在接口上时,则子类中要指定实现接口类型,同时还可以子类也可以定义为泛型类
泛型的高级应用:?通配符
当指定两种泛型的集合,则迭代时也要定义两种泛型的迭代器,麻烦,此时可通过将迭代器的泛型改为?,如Iterator<?> it=al.iterator();
两种泛型限定:
向上限定: ? extends E ;E可以接收E类型或者E的子类。
向下限定: ? super E ;E可以接收E类型或者E的父类。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: