亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

詳解Java中兩種分頁遍歷的使用姿勢

瀏覽:2日期:2022-08-15 18:26:32

在日常開發中,分頁遍歷迭代的場景可以說非常普遍了,比如掃表,每次撈100條數據,然后遍歷這100條數據,依次執行某個業務邏輯;這100條執行完畢之后,再加載下一百條數據,直到掃描完畢

那么要實現上面這種分頁迭代遍歷的場景,我們可以怎么做呢

本文將介紹兩種使用姿勢

常規的使用方法 借助Iterator的使用姿勢1. 數據查詢模擬

首先mock一個分頁獲取數據的邏輯,直接隨機生成數據,并且控制最多返回三頁

public static int cnt = 0;private static List<String> randStr(int start, int size) { ++cnt; if (cnt > 3) { return Collections.emptyList(); } else if (cnt == 3) { cnt = 0; size -= 2; } System.out.println('======================= start to gen randList ===================='); List<String> ans = new ArrayList<>(size); for (int i = 0; i < size; i++) { ans.add((start + i) + '_' + UUID.randomUUID().toString()); } return ans;}2. 基本實現方式

針對這種場景,最常見也是最簡單直觀的實現方式

while死循環 內部遍歷

private static void scanByNormal() { int start = 0; int size = 5; while (true) { List<String> list = randStr(start, size); for (String str : list) { System.out.println(str); } if (list.size() < size) { break; } start += list.size(); }}3. 迭代器實現方式

接下來介紹一種更有意思的方式,借助迭代器的遍歷特性來實現,首先自定義一個通用分頁迭代器

public static abstract class MyIterator<T> implements Iterator<T> { private int start = 0; private int size = 5; private int currentIndex; private boolean hasMore = true; private List<T> list; public MyIterator() { } @Override public boolean hasNext() { if (list != null && list.size() > currentIndex) { return true; } // 當前的數據已經加載完畢,嘗試加載下一批 if (!hasMore) { return false; } list = load(start, size); if (list == null || list.isEmpty()) { // 沒有加載到數據,結束 return false; } if (list.size() < size) { // 返回條數小于限制條數,表示還有更多的數據可以加載 hasMore = false; } currentIndex = 0; start += list.size(); return true; } @Override public T next() { return list.get(currentIndex++); } public abstract List<T> load(int start, int size);}

接下來借助上面的迭代器可以比較簡單的實現我們的需求了

private static void scanByIterator() { MyIterator<String> iterator = new MyIterator<String>() { @Override public List<String> load(int start, int size) { return randStr(start, size); } }; while (iterator.hasNext()) { String str = iterator.next(); System.out.println(str); }}

那么問題來了,上面這種使用方式比前面的優勢體現再哪兒呢?

雙層循環改為單層循環

接下來接入重點了,在jdk1.8引入了函數方法 + lambda之后,又提供了一個更簡潔的使用姿勢

public class IteratorTestForJdk18 { @FunctionalInterface public interface LoadFunc<T> { List<T> load(int start, int size); } public static class MyIterator<T> implements Iterator<T> { private int start = 0; private int size = 5; private int currentIndex; private boolean hasMore = true; private List<T> list; private LoadFunc<T> loadFunc; public MyIterator(LoadFunc<T> loadFunc) { this.loadFunc = loadFunc; } @Override public boolean hasNext() { if (list != null && list.size() > currentIndex) {return true; } // 當前的數據已經加載完畢,嘗試加載下一批 if (!hasMore) {return false; } list = loadFunc.load(start, size); if (list == null || list.isEmpty()) {// 沒有加載到數據,結束return false; } if (list.size() < size) {// 返回條數小于限制條數,表示還有更多的數據可以加載hasMore = false; } currentIndex = 0; start += list.size(); return true; } @Override public T next() { return list.get(currentIndex++); } }}

在jdk1.8及之后的使用姿勢,一行代碼即可

private static void scanByIteratorInJdk8() { new MyIterator<>(IteratorTestForJdk18::randStr) .forEachRemaining(System.out::println);}

這次對比效果是不是非常顯眼了,從此以后分頁迭代遍歷再也不用冗長的雙重迭代了

到此這篇關于詳解Java中兩種分頁遍歷的使用姿勢的文章就介紹到這了,更多相關Java 分頁遍歷內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 九九热视频在线观看 | heyzo北条麻妃中文字幕 | 欧美一级特黄乱妇高清视频 | 欧美成人性生活视频 | 俺去鲁婷婷六月色综合 | 毛片毛片毛片毛片毛片毛片 | 欧美精品在线观看视频 | 国产手机在线小视频免费观看 | 亚洲国产天堂久久综合226 | 亚洲国产精 | 国产欧美亚洲精品第二区首页 | 亚洲欧美日韩在线精品2021 | 欧美一区二区三区在线观看不卡 | 亚洲精品网站在线观看不卡无广告 | 国产精品免费一级在线观看 | 伊人丁香婷婷综合一区二区 | 国产精品一区欧美日韩制服 | 国产福利在线观看永久视频 | 欧美成人做性视频在线播放 | 福利入口在线观看 | 黄色a一级片 | 亚洲成人aaa | 亚洲一区二区在线免费观看 | 国产精品亚洲专区在线播放 | 日本一级毛片免费看 | 久久亚洲精品23p | 亚洲黄色a级片 | 黄色片免费在线观看视频 | 国产动作大片中文字幕 | 久久99精品久久久久久首页 | 一级黄色片一级黄色片 | 亚洲综合一区二区 | 亚洲精品啪啪一区二区三区 | 香蕉视频国产精品人 | 久久777国产线看是看精品 | 国产精品一区二区在线观看 | 97视频在线观看视频在线精品 | 国产精品久久久久久久毛片 | 天天草夜夜骑 | 国产美女亚洲精品久久久综合 | 成人毛片18女人毛片免费 |