Java数据结构简易对比
来源:互联网 发布:上瘾网络剧发布会 编辑:程序博客网 时间:2024/05/18 01:30
Collection
├List ……………………………………..有顺序
│├LinkedList………………………….├链表形式,非线程安全
│├ArrayList…………………………….├数组形式,非线程安全
│└Vector………………………………..├数组形式,线程安全
│ └Stack………………………………….├栈形式,线程安全
└Set……………………………………….无顺序,堆形式,数据不可重复
Map……………………………………….键值对,key不可以相同
├Hashtable…………………………….├任何非空的key/value,线程安全
├HashMap……………………………..├允许null key/value,非线程安全
└WeakHashMap…………………….├对’key’是弱引用,不再被外部引用,会被GC
一:使用synchronized关键字,这个大家应该都很熟悉了,不解释了;
二:使用Collections.synchronizedList();
使用方法如下:
假如你创建的代码如下:List<Map<String,Object>> data=new ArrayList<Map<String,Object>>();
那么为了解决这个线程安全问题你可以这么使用Collections.synchronizedList(),如:
List<Map<String,Object>> data=Collections.synchronizedList(new ArrayList<Map<String,Object>>());
其他的都没变,使用的方法也几乎与ArrayList一样,大家可以参考下api文档;
额外说下 ArrayList与LinkedList;这两个都是接口List下的一个实现,用法都一样,但用的场所的有点不同,ArrayList适合于进行大量的随机访问的情况下使用,LinkedList适合在表中进行插入、删除时使用,二者都是非线程安全,解决方法同上(为了避免线程安全,以上采取的方法,特别是第二种,其实是非常损耗性能的)。
[参考资料]
- JAVA集合小结
- java中的各个数据结构区别
- Java数据结构简易对比
- 对比JAVA学习PHP系列:数据结构
- Ceph与Swift简易对比
- 【数据结构】malloc简易用法
- 数据结构 简易计算器
- 数据结构中Java实现KMP与BF算法对比
- 数据结构的优缺点对比
- 语言对比-数据结构
- 常见数据结构对比
- Java数据结构与算法之数据结构-逻辑结构-集合(六)------集合之ArrayList和LinkedList对比
- (数据结构)简易文本编辑器
- 数据结构之简易版hashmap
- 数据结构(JAVA版本)练习之集合 简易图书管理系统
- 【数据结构】-常用排序算法对比
- 数据结构各种排序的对比
- JAVA绝对干货——List、Set、Map并发数据结构对比实现
- JAVA绝对干货——List、Set、Map并发数据结构对比实现
- 对比java和python对比
- c#泛型约束
- 项目实践-导航管理一
- IOS开发之实现App消息推送(最新)
- iOS Xcode 上传App Store .bundle报错解决方法
- 如何成为一名入门级 iOS 开发者
- Java数据结构简易对比
- Neo4j简介
- Python基础02 基本数据类型
- Xcode预处理命令、控制台调试命令、 iOS事件拦截
- Android系统信息获取
- 使用Xutils框架优化ListView
- BZOJ_P2301&Codevs_P1858 [HAOI2011]Problem b(数论+容斥原理)
- 解决CentOS遇到Qt编译(error: cannot find -lGL)
- 编程中的一些概念,KISS、DRY、MVC、OOP、REST