Java程序员的日常 —— 《编程思想》持有对象
集合框架可以说是Java里面必备的知识点了,日常的使用中也会遇到各种情况需要使用到集合。下面就简单介绍下各种集合的使用场景:
List
List可以看做是数组,实现的方式有两种:
- ArrayList 适合随机访问
- LinkedList 适合做插入删除操作
Queue和Stack
这两种数据结构都可以通过LinkedList来实现
Map
Map用于保存键值对,常用的实现方式有:
- HashMap 使用散列表实现
- TreeMap 基于红黑树,保证键的排序
- LinkedHashMap 基于链表的哈希,能保证插入的顺序性
Set
与Map相比,set不接受重复的值
实现的方式与Map类似。
工具类
其实就俩,Collections以及Arrays,有空就需要看看。
技巧
首先可以通过iterator遍历列表以及map。用户也可以自己定义iterator实现倒序遍历。
如:
class ReversibleArrayList<T> extends ArrayList<T>{
public ReversibleArrayList(Collection<T> c){
super(c);
}
public Iterable<T> reversed(){
return new Iterable<T>() {
public Iterator<T> iterator(){
return new Iterator<T>(){
int current = size() -1 ;
public boolean hasNext(){
return current > -1;
}
public T next(){
return get(current--);
}
public void remove(){
throw new UnsupportedOperationException();
}
};
}
};
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
2015-05-29 我的大学 --- 与书为伴
2014-05-29 剑指OFFER之反转链表(九度OJ1518)