发布网友
共4个回答
热心网友
Iterator是迭代器类,而Iterable是接口。
好多类都实现了Iterable接口,这样对象就可以调用iterator()方法。
一般都是结合着用,比如
HashMap类就实现了Iterable接口,而要访问或打印出Map中所有内容时,就可以这样: HashMap hashMap;
Iterator iter = hashMap.iterator();
while(iter.hashNext()) {
String s = iter.next();
}
转至:http://liuyun025.iteye.com/blog/1321045
为什么一定要实现Iterable接口,为什么不直接实现Iterator接口呢?
看一下JDK中的集合类,比如List一族或者Set一族,都是实现了Iterable接口,但并不直接实现Iterator接口。
仔细想一下这么做是有道理的。
因为Iterator接口的核心方法next()或者hasNext() 是依赖于迭代器的当前迭代位置的。
如果Collection直接实现Iterator接口,势必导致集合对象中包含当前迭代位置的数据(指针)。
当集合在不同方法间被传递时,由于当前迭代位置不可预置,那么next()方法的结果会变成不可预知。
除非再为Iterator接口添加一个reset()方法,用来重置当前迭代位置。
但即时这样,Collection也只能同时存在一个当前迭代位置。
而Iterable则不然,每次调用都会返回一个从头开始计数的迭代器。
多个迭代器是互不干扰的。
热心网友
因为你里面存的全是String类型的,所以就会显示 的一样,如果你修改一个值不是String类型的,就会输不出来了吧。。
next()方法返回值类型是和你这里定义的<String>一致的
E
next()
Returns the next element in the iteration.p这句是api里面摘抄出来的,你可以看看
热心网友
<E>是泛型 指定集合内元素的类型,不写也可以会有警告,指定泛型可以提高程序的执行效率
如果指定了<String> 那不是String类型的元素将会出错
热心网友
<string>在这里是泛型,你上面那句不写tostring(),得到的也是string类型的数据。
热心网友
Iterator是迭代器类,而Iterable是接口。
好多类都实现了Iterable接口,这样对象就可以调用iterator()方法。
一般都是结合着用,比如
HashMap类就实现了Iterable接口,而要访问或打印出Map中所有内容时,就可以这样: HashMap hashMap;
Iterator iter = hashMap.iterator();
while(iter.hashNext()) {
String s = iter.next();
}
转至:http://liuyun025.iteye.com/blog/1321045
为什么一定要实现Iterable接口,为什么不直接实现Iterator接口呢?
看一下JDK中的集合类,比如List一族或者Set一族,都是实现了Iterable接口,但并不直接实现Iterator接口。
仔细想一下这么做是有道理的。
因为Iterator接口的核心方法next()或者hasNext() 是依赖于迭代器的当前迭代位置的。
如果Collection直接实现Iterator接口,势必导致集合对象中包含当前迭代位置的数据(指针)。
当集合在不同方法间被传递时,由于当前迭代位置不可预置,那么next()方法的结果会变成不可预知。
除非再为Iterator接口添加一个reset()方法,用来重置当前迭代位置。
但即时这样,Collection也只能同时存在一个当前迭代位置。
而Iterable则不然,每次调用都会返回一个从头开始计数的迭代器。
多个迭代器是互不干扰的。
热心网友
因为你里面存的全是String类型的,所以就会显示 的一样,如果你修改一个值不是String类型的,就会输不出来了吧。。
next()方法返回值类型是和你这里定义的<String>一致的
E
next()
Returns the next element in the iteration.p这句是api里面摘抄出来的,你可以看看
热心网友
<E>是泛型 指定集合内元素的类型,不写也可以会有警告,指定泛型可以提高程序的执行效率
如果指定了<String> 那不是String类型的元素将会出错
热心网友
<string>在这里是泛型,你上面那句不写tostring(),得到的也是string类型的数据。