java中的以下几大集合:

List结构的集合类:

ArrayListl类,LinkedList类,Vector类,stack类

Map结构的集合类:

HashMap类,Hashtable类(此是以key,value的键值对的形式存在的)

Set结构的集合类

HashSet类,TreeSet类

Queue结构的集合类

Queue接口

集合中的一些区别:

HashMap和Hashtable的区别

HashMap与HashTable都是java的集合类,都可以用来存放对象,这是他们的相同点,但他们也有区别:

一,历史原因:

Hashtable是基于陈旧的Dictionary类的,HashMap是java 1.2 引进的Map接口的一个实现。

二,同步性:

Hashtable是同步的,这个类中的一些方法保证了Hashtable中的对象是线程安全的。

而HashMap则是异步的,因此HashMap中的对象并不是线程安全的,因为同步的要求会影响执行的效率,

所以如果你不需要线程安全的集合那么使用HashMap是一个很好的选择,这样可以避免由于同步带来不必要的开销

从而提高效率。

三.值:HashMap可以让你将空值作为一个表的条目的key或value

但是Hashtable 是不能放入空值的(null);

ArrayList和Vector的区别

ArrayList与Vector都是java的集合类,都可以用来存放java对象的,这是相同点

不同之处:

一,同步性:

Vector是同步的。这个类中的一些方法保证了Vector中的对象是线程安全的。而ArrayList则是异步的,

因此ArrayList中的对象并不是线程安全的,因为同步的要求会影响执行效率,所以如果你不需要线程安全

的集合那么使用ArrayList是一个很好的选择,这样可以避免由同步带来的不必要的性能开销。

二,数据增长:

从内部实现机制来讲ArrayList和Vector都是使用数组(Array)来控制集合中的对象。当你向这两种类型中增加

元素的时候,如果元素的数目超出了内部的数组目前的长度它们就需要扩展内部数组的长度,Vector缺省情况下

自动增长原来一倍的数组长度,ArrayList是原来的50%,所以最后你获得的这个集合所占的空间总是比你实际需

要的要大。所以如果你要在集合中保存大量的数据那么使用Vector有一些优势,因为你可以通过设置集合的初始化

大小来避免不必要的资源开销。

最新文章

  1. Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池
  2. 点击div区域以外部分,div区域隐藏
  3. 用JS打开网页时自动更改css样式,可用于处理浏览器兼容
  4. Matlab与C/C++联合编程之Matlab以MEX方式调用C/C++代码(二)
  5. Oracle 基础 —SQL语句优化的途径
  6. TCL语言笔记:TCL中的数组
  7. C语言关键字-volatile
  8. 【转】webAPP快速入门
  9. matlab 全局变量的使用举例
  10. The struts dispatcher cannot be found
  11. H5的canvas绘图技术
  12. Quartz.NET 入门教程
  13. TF-IDF 提取关键词
  14. Java 平时作业五
  15. eclipse 安装MyBatis插件 -- 官网直接拖动“安装”
  16. node 常用模块及方法fs,url,http,path
  17. postgrepsql 创建函数
  18. MySQL灾备恢复在线主从复制变成主主复制及多源复制【转】
  19. 《学习R》
  20. task.factory.startnew()

热门文章

  1. 线程池(3)Executors.newCachedThreadPool
  2. Polly+AspectCore实现熔断与降级机制
  3. 《深入理解java虚拟机》笔记(7)JVM调优(分代垃圾收集器)
  4. Spark Mllib里如何提取每个字段并转换为***类型(图文详解)
  5. 「干货分享」模块化编程和maven配置实践一则
  6. 4. 把一幅彩色图像的R、G、B分量单独显示。
  7. readonly与const的区别
  8. 邮箱/邮件地址的正则表达式及分析(JavaScript,email,regex)
  9. eclipse的垂直选择功能
  10. 用NPOI操作EXCEL-锁定列CreateFreezePane()