mk_*_*mk_ 27 java foreach iterable
我有Book和BookList课.BookList是这样的:
public class BookList
{
private final List<Book> bList = new ArrayList<Book>();
public int size() { return bList.size(); }
public boolean isEmpty() { ... }
public boolean contains(Book b) { ... }
public boolean add(Book b) { ... }
public boolean remove(Book b) { .. }
public void clear() { ... }
public Object get(int index) { ... }
}
Run Code Online (Sandbox Code Playgroud)
在我的主要课程中,我想在每个循环中打印书籍的标题:
for(Book b : bList)
{
b.print();
}
Run Code Online (Sandbox Code Playgroud)
Eclipse说:
只能遍历数组或java.lang.Iterable的实例
我怎样才能使这个工作?
and*_*ler 31
您需要实现该Iterable接口,这意味着您需要实现该iterator()方法.在您的情况下,这可能看起来像这样:
public class BookList implements Iterable<Book> {
private final List<Book> bList = new ArrayList<Book>();
@Override
public Iterator<Book> iterator() {
return bList.iterator();
}
...
}
Run Code Online (Sandbox Code Playgroud)
Ste*_*n C 25
实现Iterable接口.这意味着您需要实现一个方法,该方法返回一个Iterator将遍历一个元素的对象BookList.
在这种情况下,您的iterator()方法可以只返回调用的结果bList.iterator().(这将导致for (Book b : somBookList)迭代...中的Book对象BookList.bList)
在其他情况下,你可能需要编写自己的Iterator<T>实现类,完整的T next(),boolean hasNext()和remove()方法.例如,如果您想阻止外部代码从BookList通过迭代器中删除元素,您可以像这样实现它:
public class BookList implements Iterable<Book> {
private final List<Book> bList = new ArrayList<Book>();
//...
@Override
public Iterator<Book> iterator() {
return new Iterator<Book> () {
private final Iterator<Book> iter = bList.iterator();
@Override
public boolean hasNext() {
return iter.hasNext();
}
@Override
public Book next() {
return iter.next();
}
@Override
public void remove() {
throw new UnsupportedOperationException("no changes allowed");
}
};
}
}
Run Code Online (Sandbox Code Playgroud)
小智 7
在这里,我们可以看到使用iterator和foreach语法的LinkedList的简单实现
class LinkedList implements Iterable<LinkedList.Node>{
private Node node;
public void add(Object data){
if(!Optional.ofNullable(node).isPresent()){
node = new Node();
node.setData(data);
}else{
Node node = new Node();
node.setData(data);
Node lastNode = getLastNode(this.node);
lastNode.setNext(node);
}
}
private Node getLastNode(Node node){
if(node.getNext()==null){
return node;
}else{
return getLastNode(node.getNext());
}
}
class Node{
private Object data;
private Node next;
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
public Node getNext() {
return next;
}
public void setNext(Node next) {
this.next = next;
}
}
public Iterator<Node> iterator() {
return new NodeIterator();
}
class NodeIterator implements Iterator<Node>{
private Node current;
public boolean hasNext() {
if(current == null){
current = node;
return Optional.ofNullable(current).isPresent();
}else{
current = current.next;
return Optional.ofNullable(current).isPresent();
}
}
public Node next() {
return current;
}
}
}
public class LinkedListImpl {
public static void main(String[] args) {
LinkedList linkedList = new LinkedList();
linkedList.add("data1");
linkedList.add("data2");
linkedList.add("data3");
for(LinkedList.Node node: linkedList){
System.out.println(node.getData());
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
33019 次 |
| 最近记录: |