【机试题】LazyIterator迭代器懒加载问题

将下面这个未完成的Java工具类补充完成,实现懒加载的功能,该类需要实现Iterable接口,能够遍历所有数据。具体要求如下:

工具类提供了一个ValueLoader接口,用于获取数据,其中ValueLoader的接口定义为:public interface ValueLoader { List load(long offset, int limit); }。使用该工具类的地方,需要提供ValueLoader的实现类。

工具类需要支持懒加载,即遍历时按需获取数据,而非一次性获取所有数据到内存之后,再进行遍历;

工具类需要实现Iterable接口,支持使用foreach语句遍历所有数据;

当ValueLoader.load()方法返回null时,认为已经遍历完成;

待补充完整的工具类:

实际场景使用该类的范例

解答:

补充完整后的LazyIterator

java 复制代码
import java.util.Iterator;  
import java.util.List;  
  
public class LazyIterator<T> implements Iterable<T> {  
  
    private final ValueLoader<T> valueLoader;  
    private List<T> data;  
    private long offset;  
    private int limit;  
    private Iterator<T> iterator;  
  
    @Override  
    public Iterator<T> iterator() {  
        if (iterator == null) {  
            loadData();  
        }  
        return iterator;  
    }  
  
    public LazyIterator(ValueLoader<T> valueLoader) {  
        this.valueLoader = valueLoader;  
        this.offset = 0;  
        this.limit = Integer.MAX_VALUE; // 设置初始限制为Integer最大值,加载所有数据  
        this.iterator = new Itr();  
    }  
  
    private void loadData() {  
        data = valueLoader.load(offset, limit);  
        if (data == null) {  
            // 数据加载完毕,设置迭代器为false,表示遍历完成  
            iterator = null;  
        } else {  
            iterator = data.iterator();  
        }  
    }  
  
    private class Itr implements Iterator<T> {  
        @Override  
        public boolean hasNext() {  
            if (data == null) {  
                loadData(); // 加载数据  
            }  
            return iterator.hasNext();  
        }  
  
        @Override  
        public T next() {  
            if (data == null) {  
                loadData(); // 加载数据  
            }  
            return iterator.next();  
        }  
    }  
}

public interface ValueLoader<T> {
   List<T> load(long offset,int limit);
}
相关推荐
星释9 分钟前
Rust 练习册 16:Trait 作为返回类型
java·网络·rust
2301_7965125211 分钟前
Rust编程学习 - 如何理解Rust 语言提供了所有权、默认move 语义、借用、生命周期、内部可变性
java·学习·rust
乐悠小码15 分钟前
Java设计模式精讲---03建造者模式
java·设计模式·建造者模式
一个人的幽默22 分钟前
聊一下java获取客户的ip
java
披着羊皮不是狼25 分钟前
Spring Boot——从零开始写一个接口:项目构建 + 分层实战
java·spring boot·后端·分层
Deamon Tree1 小时前
【设计题】如何实现限流器
java
短视频矩阵源码定制2 小时前
矩阵系统哪个好?2025年全方位选型指南与品牌深度解析
java·人工智能·矩阵·架构·aigc
kpli902 小时前
Java开发性能优化
java·jvm
三掌柜6662 小时前
C++ 零基础入门与冒泡排序深度实现
java·开发语言·c++
卿言卿语2 小时前
CC23-最长的连续元素序列长度
java·算法·哈希算法