【机试题】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);
}
相关推荐
不倒翁玩偶14 分钟前
IDEA导入新的SpringBoot项目没有启动按钮
java·spring boot·intellij-idea
小小小米粒29 分钟前
Maven Tools
java
kali-Myon43 分钟前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
我是咸鱼不闲呀1 小时前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
清水白石0081 小时前
深入解析 LRU 缓存:从 `@lru_cache` 到手动实现的完整指南
java·python·spring·缓存
符哥20081 小时前
C++ 进阶知识点整理
java·开发语言·jvm
Sayuanni%31 小时前
初阶_多线程1(线程含义与关键属性)
java
程序媛徐师姐1 小时前
Java基于微信小程序的模拟考试系统,附源码+文档说明
java·微信小程序·java模拟考试系统小程序·模拟考试微信小程序·模拟考试系统小程序·模拟考试小程序·java模拟考试小程序
疯狂敲代码的老刘2 小时前
JDK 1.6到25 全版本网盘合集 (Windows + Mac + Linux)
java·linux·windows·macos·jdk
夕除2 小时前
js--15
java·jvm·spring