关于ListUtils.partition、Lists.partition方法的实现原理——类似于懒加载思想

背景: 最近在使用这个方法的时候好奇是如何实现的,就点进去查看一下源码,源码如下:

在上面图中可以看到调用了ListUtils.partition方法,在方法中new了一个Partition对象就直接return了并没有对原始的list做分割操作。

于是就比较好奇这个方法是怎么实现list的分割的呢?

分析: 从源码中可以看到Partition这个内部类中有三个方法 get size isEmpty。从代码中不难发现真正处理分割list的方法是get方法中list.subList()这个方法起作用。

于是在idea中debug,查看上图中partition这个对象时发现integers已经按照每个List3个元素分割成了2个List了。但是源码中只是创建了一个Partition类过后啥都没做。那么到什么时候调用到Partition.get()这个方法呢。

在网上查了下资料 IntelliJ IDEA 的调试中,当你查看某个对象的值时,实际上会调用该对象的 toString() 方法来获取其字符串表示形式,以便在调试器中显示。

Partition继承了AbstractList,AbstractList抽象类继承了AbstractCollection抽象类,而AbstractCollection重写了toString方法,AbstractList和Partition均未重写该方法,说明调用就是AbstractCollection类的toString方法。下图是AbstractCollection类的toString方法

而toString里面使用了迭代器,而真正调用到Partition.get()是在迭代器的next方法中。在AbstractList中如下图:

所以ListUtils.partition这个方法并没有直接做分割操作,而是在我查看partition对象时,触发了partition.toString()方法才真正的对原始List做了分割。这是一种懒加载的思想。

同样的对partition对象做遍历操作,由于for循环底层上还是通过迭代器来实现的,那么这也是在使用的时候才分割的List。

另外Google Guava库中的Lists.partition方法也是类似的实现

总结:使用了懒加载的思想的优点

  1. 节省内存资源:使用懒加载的方式,不需要一次性将所有的子列表都生成出来,而是按需生成。这意味着在处理大型列表时,只有当前需要的子列表会被生成,而不会同时占用大量内存资源。这对于内存受限的环境下特别有用。
  2. 提高性能:由于不需要一次性生成所有的子列表,懒加载能够减少不必要的计算和内存分配,从而提高了程序的性能。特别是当处理的数据量很大时,避免了一次性加载整个数据集合所带来的性能问题。
  3. 灵活性:懒加载使得数据在需要时才被加载,这意味着可以根据实际需求动态地生成数据,而不需要预先分配所有可能的情况。这种灵活性使得程序更容易适应不同的需求和场景。
  4. 简化代码逻辑 :懒加载的方式使得代码逻辑更加简洁明了。不需要手动管理生成子列表的过程,而是由ListUtils.partition方法自动按需生成,减少了代码的复杂性和错误的可能性。

总的来说,懒加载思想在ListUtils.partition方法中的应用使得对大型数据集合的处理更加高效、灵活,并且能够节省内存资源,提高程序性能。

相关推荐
无限的鲜花3 小时前
反射(原创推荐)
java·开发语言
IT二叔3 小时前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
一路向北he4 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
超级数据查看器4 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
折哥的程序人生 · 物流技术专研5 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai5 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
硕风和炜6 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
格子软件6 小时前
2026年GEO贴牌代理:分布式多级分账状态机源码深度解构
java·vue.js·分布式·vue·geo
我是一颗柠檬7 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农7 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法