java Iterable接口 解释一段程序
下面的这段程序请详细解释一下,结构以及执行过程,多谢了importjava.util.*;publicclassIterableClassimplementsIterab...
下面的这段程序请详细解释一下,结构以及执行过程,多谢了
import java.util.*;
public class IterableClass implements Iterable<String> {
protected String[] words = ("And that is how "
+ "we know the Earth to be banana-shaped.").split(" ");
public Iterator<String> iterator() {
return new Iterator<String>() {
private int index = 0;
public boolean hasNext() {
return index < words.length;
}
public String next() {
return words[index++];
}
public void remove() { // Not implemented
throw new UnsupportedOperationException();
}
};
}
public static void main(String[] args) {
for (String s : new IterableClass())
System.out.print(s + " ");
}
} 展开
import java.util.*;
public class IterableClass implements Iterable<String> {
protected String[] words = ("And that is how "
+ "we know the Earth to be banana-shaped.").split(" ");
public Iterator<String> iterator() {
return new Iterator<String>() {
private int index = 0;
public boolean hasNext() {
return index < words.length;
}
public String next() {
return words[index++];
}
public void remove() { // Not implemented
throw new UnsupportedOperationException();
}
};
}
public static void main(String[] args) {
for (String s : new IterableClass())
System.out.print(s + " ");
}
} 展开
2个回答
展开全部
Iterator是一个遍历器。它相当于一个游标,刚开始时指向要遍历的集合(比如程序中的String数组)的第一个元素之前,然后每调用一次next()方法,这个游标就会向前走一格,当走到集合最后一个元素之后,hasNext()方法会返回false,表示游标已经走到最后,没有下一个值了。
以下是详细注释:
import java.util.*;
public class IterableClass implements Iterable<String> {
protected String[] words = ("And that is how "
+ "we know the Earth to be banana-shaped.").split(" ");//将这段字符串按照“ ”来分解成一个字符串数组,即words[0]=And words[1]=that words[2]=is ........
public Iterator<String> iterator() {
return new Iterator<String>() {这里声明了一个实现Iterator接口的匿名内部类,并返回了内部类的实例
private int index = 0;//字符串数组的下标标记,相当于一个游标,每调用一次next()方法,下标就会加1,就是说游标往前走一格,当这个下标等于或者大于字符数组的长度的时候,表示游标走到最后一个元素之后了,没有下一个元素了
public boolean hasNext() {
return index < words.length;//判断下标是不是大于或等于数组长度了,是的话返回false,表示游标走到最后了
}
public String next() {
return words[index++];//先返回当前游标指向的words数组里的数据,然后游标往前走(index++).
}
public void remove() { // Not implemented hasNext() 和next()方法都是重写接口里的抽象方法,而这个不是。
throw new UnsupportedOperationException();//抛出异常
}
};
}
//至于这个main方法。。。不能体现Iterator的使用,而且这样编译不报错?!!!
/*public static void main(String[] args) {
for (String s : new IterableClass())
System.out.print(s + " ");
}*/
//应该这样写:
public static void main(String args[]){
IterableClass itTest=new IterableClass();
Iterator<String> it=itTest.iterator();//获得匿名内部类的对象,即获得遍历器
while(it.hasNext()){//判断游标当前指向的是不是尾部
String a=it.next();//取出游标当前之乡的值,然后游标往前走一格(index++)
System.out.println(a);
}
}
}
以下是详细注释:
import java.util.*;
public class IterableClass implements Iterable<String> {
protected String[] words = ("And that is how "
+ "we know the Earth to be banana-shaped.").split(" ");//将这段字符串按照“ ”来分解成一个字符串数组,即words[0]=And words[1]=that words[2]=is ........
public Iterator<String> iterator() {
return new Iterator<String>() {这里声明了一个实现Iterator接口的匿名内部类,并返回了内部类的实例
private int index = 0;//字符串数组的下标标记,相当于一个游标,每调用一次next()方法,下标就会加1,就是说游标往前走一格,当这个下标等于或者大于字符数组的长度的时候,表示游标走到最后一个元素之后了,没有下一个元素了
public boolean hasNext() {
return index < words.length;//判断下标是不是大于或等于数组长度了,是的话返回false,表示游标走到最后了
}
public String next() {
return words[index++];//先返回当前游标指向的words数组里的数据,然后游标往前走(index++).
}
public void remove() { // Not implemented hasNext() 和next()方法都是重写接口里的抽象方法,而这个不是。
throw new UnsupportedOperationException();//抛出异常
}
};
}
//至于这个main方法。。。不能体现Iterator的使用,而且这样编译不报错?!!!
/*public static void main(String[] args) {
for (String s : new IterableClass())
System.out.print(s + " ");
}*/
//应该这样写:
public static void main(String args[]){
IterableClass itTest=new IterableClass();
Iterator<String> it=itTest.iterator();//获得匿名内部类的对象,即获得遍历器
while(it.hasNext()){//判断游标当前指向的是不是尾部
String a=it.next();//取出游标当前之乡的值,然后游标往前走一格(index++)
System.out.println(a);
}
}
}
展开全部
过程很简单从main函数执行
for (String s : new IterableClass())这句相当于将words数组中的每个值赋给string s
类似于for(int i=0;i<word数组长度;i++) s=words[i];
结构:IterableClass类里面有个函数public Iterator<String> iterator()
函数里面反回了一个新的Iterator<String>()对象
下面这部分相当于重写了Iterator<String>()里面的一些方法
{
private int index = 0;
public boolean hasNext() {
return index < words.length;
}
public String next() {
return words[index++];
}
public void remove() { // Not implemented
throw new UnsupportedOperationException();
}
};
for (String s : new IterableClass())这句相当于将words数组中的每个值赋给string s
类似于for(int i=0;i<word数组长度;i++) s=words[i];
结构:IterableClass类里面有个函数public Iterator<String> iterator()
函数里面反回了一个新的Iterator<String>()对象
下面这部分相当于重写了Iterator<String>()里面的一些方法
{
private int index = 0;
public boolean hasNext() {
return index < words.length;
}
public String next() {
return words[index++];
}
public void remove() { // Not implemented
throw new UnsupportedOperationException();
}
};
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询