首页 > 代码库 > 常用数据结构
常用数据结构
1、Hashtable,哈希表是根据关键码值(Key value)直接进行访问的数据结构。它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。
HashMap,一个HashMap的实际容量=容量x因子,默认值是16×0.75=12。当存入HashMap的对象超过这个容量时,HashMap会重新构造存取表(长度变为原来的2倍,然后一个个indexfor进去),这是一个大问题,所以当你知道大概要存放多少个对象时,最好设为该实际容量能接受的数字。对于冲突,Java HashMap采用的是链表的方式来存储的。HashMap不保证映射的顺序,特别是它不保证该顺序恒久不变。
Hashtable和HashMap的区别:
①.Hashtable的方法是同步的,而HashMap的方法不是,在多线程环境下,HashMap就可能存在出问题(即HashMap是非线程安全的)。这个问题可以用Collections类的静态的synchronizedMap()方法来解决,它创建一个线程安全的Map对象,并把它作为一个封装的对象来返回。
②.Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现(经常优先选择HashMap)。
③.Hashtable不允许使用null值和null键,但HashMap可以。
<script src="https://code.csdn.net/snippets/344403.js" type="text/javascript"></script>
(2014-05-13 晚)
2、树
3、图
4、链表、队列、栈、Map
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。