高兴技术 JDK1.5新特性(六)
2013-09-18 14:21
232 查看
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的父类。
相关文章推荐
- java基础--高薪技术--JDK1.5新特性
- java高薪技术——jdk1.5新特性和枚举
- OSChina 技术周刊第二十四期 —— C# 6.0 的新特性
- XML解析技术的特性比较与选择
- JDK1.5新特性,基础类库篇,扫描类(Scanner)用法
- VOIP技术连载之四--接口、特性介绍
- 黑马程序员—JAVA高新技术_JDK1.5新特性II
- JDK1.5新特性,基础类库篇,System类
- 黑马程序员_java集合框架工具类及JDK1.5新特性
- JDK1.5新特性
- Docker容器技术和传统虚拟机技术的特性比较
- 线程基础:JDK1.5+(8)——线程新特性(上)
- 【转】JDK1.5-1.9新特性
- 黑马程序员——Java基础:反射、JDK1.5新特性、正则表达式
- 黑马程序员_日记18_Java多线程(八)--生产者消费者问题JDK1.5特性
- JDK1.5 引入的新特性
- Java基础加强_JDK1.5新特性
- java--JDK1.5新特性
- C++11 的新特性对C++技术格局的影响
- 黑马程序员-jdk1.5新特性