黑马程序员技术交流社区

标题: jdk1.5新特性 [打印本页]

作者: qincai    时间: 2014-6-10 23:55
标题: jdk1.5新特性
本帖最后由 qincai 于 2014-6-13 22:43 编辑

jdk1.5新特性都有什么?

作者: felixzr    时间: 2014-6-11 00:10
泛型(Generics)--为集合(collections)提供编译时类型安全,无需每刻从Collections取得一个对象就进行强制转

增强的“for”循环(Enhanced For loop)--减少迭代器(iterator)的潜在错误(error-proneness)
目前这是我知道的
作者: MasMajesty    时间: 2014-6-11 00:29
增强for循环

格式:
//增强for循环括号里写两个参数,第一个是声明一个变量,第二个就是需要迭代的容器?
for(元素类型 变量名 : Collection集合 & 数组 ) { }

高级for循环和传统for循环的区别:?
高级for循环在使用时,必须要明确被遍历的目标。这个目标,可以是Collection集合或者数组,如果遍历Collection集合,
在遍历过程中还需要对元素进行操作,比如删除,需要使用迭代器。

如果遍历数组,还需要对数组元素进行操作,建议用传统for循环因为可以定义角标通过角标操作元素。
如果只为遍历获取,可以简化成高级for循环,它的出现为了简化书写。

高级for循环可以遍历map集合吗?
不可以。但是可以将map转成set后再使用foreach语句。
1)、作用:对存储对象的容器进行迭代: 数组  collection  map
2)、增强for循环迭代数组:
String[] arr = {"a", "b", "c"};//数组的静态定义方式,只适用于数组首次定义的时候
for(String s : arr)
{
    System.out.println(s);
  }
3)、单列集合 Collection:
List list = new ArrayList();
list.add("aaa");
//增强for循环, 没有使用泛型的集合能不能使用增强for循环迭代?


for(Object obj : list)
{
  String s = (String) obj;
   System.out.println(s); }

4)、双列集合 Map:
Map map = new HashMap();
map.put("a", "aaa");
// 传统方式:必须掌握这种方式
Set entrys = map.entrySet();

//1.获得所有的键值对Entry对象
iter = entrys.iterator();

//2.迭代出所有的entry

while(iter.hasNext()) {
Map.Entry entry = (Entry) iter.next();

String key = (String) entry.getKey();

//分别获得key和value

String value = (String) entry.getValue();
System.out.println(key + "=" + value); }

// 增强for循环迭代:原则上map集合是无法使用增强for循环来迭代的,因为增强for循环只能针对实现了Iterable接口的集合进行迭代;
Iterable是jdk5中新定义的接口,就一个方法iterator方法,只有实现了Iterable接口的类,才能保证一定有iterator方法,
java有这样的限定是因为增强for循环内部还是用迭代器实现的,而实际上,我们可以通过某种方式来使用增强for循环。

for(Object obj : map.entrySet())
{
     Map.Entry entry = (Entry) obj; // obj 依次表示Entry
    System.out.println(entry.getKey() + "=" + entry.getValue()); }

5)、集合迭代注意问题:在迭代集合的过程中,不能对集合进行增删操作(会报并发访问异常);
   可以用迭代器的方法进行操作(子类listIterator:有增删的方法)。
6)、增强for循环注意问题:在使用增强for循环时,不能对元素进行赋值;
   
    int[] arr = {1,2,3};
    for(int num : arr) {
    num = 0; //不能改变数组的值
    }
    System.out.println(arr[1]);  


可变参数: ...

用到函数的参数上,当要操作的同一个类型元素个数不确定的时候,可是用这个方式,这个参数可以接受任意个数的同一类型的数据。
和以前接收数组不一样的是:
以前定义数组类型,需要先创建一个数组对象,再将这个数组对象作为参数传递给函数。
现在,直接将数组中的元素作为参数传递即可。底层其实是将这些元素进行数组的封装,而这个封装动作,是在底层完成的,被隐藏了。
所以简化了用户的书写,少了调用者定义数组的动作。
如果在参数列表中使用了可变参数,可变参数必须定义在参数列表结尾(也就是必须是最后一个参数,否则编译会失败。)。
如果要获取多个int数的和呢?
可以使用将多个int数封装到数组中,直接对数组求和即可。

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

静态导入:

当类名重名的时候,需要制定具体的包名
当方法重名时,指定具备所属的对象或者类
import static java.util.Collections.*; //导入了Collections类中的所有静态成员

作者: ★魔_➩τ咒    时间: 2014-6-11 03:48
下个API看吧
作者: 淡淡柠檬茶    时间: 2014-6-11 08:04
MasMajesty 发表于 2014-6-11 00:29
增强for循环

格式:

赞一个,给力
作者: 阿布Yocan    时间: 2014-6-11 10:05
可变参数、静态导入、增强for循环、基本数据类型的拆装箱、反射、泛型、
作者: axuan    时间: 2014-6-11 10:31
泛型(Generics)--为集合(collections)提供编译时类型安全,无需每刻从Collections取得一个对象就进行强制转换(cast)

增强的“for”循环(Enhanced For loop)--减少迭代器(iterator)的潜在错误(error-proneness)

自动置入/自动取出(Autoboxing/unboxing)--无需在基本类型(primitive types)(例如double)和包装类型(wrapper types)(例如Double)之间人工地进行转换。

类型安全的枚举(Typesafeenums)--提供类型安全枚举模式的各项好处。

静态导入(Static import)--无需在使用其他类的静态成员变量前缀其类名.这将使得代码更为简洁。

元数据(Metadata)--使编程人员避免编写样板化代码(boiler plate code),并提供机会进行宣告式程式设计(declarative programming)。
作者: 彭飞    时间: 2014-6-12 09:04
楼主好水,  我也来水一把,继续回去看视频。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2