数组与字符串简单剖析
2016-04-03 00:51
253 查看
数组和字符串的基本概念就不在说了,相信到家都知道,我们今天一起讨论下基于数组实现的散列表和ArrayList和基于string的StringBuffer。
1 散列表
何为散列表?官方给出的定义是一种能够将键(key)-映射为值(value)从而实现快速查找的数据结构。
我们接触比较多的HashMap就是对散列表的一种实现。
HashMap扩容:
初始容量默认是16,可以通过构造函数指定(指定后,其实也不是设置多少就是多少,他会是2的整数倍大于自己设置的值中的最小值),初始负载因子为0.75f,可以通过构造函数指定。极限值为负载因子*容量,默认初始为12。当使用容量大于等于极限值,容量倍增。如果倍增后的值大于最大容量1 << 30,则将桶大小修改为Integer.MAX_VALUE(1 << 31)。
2 ArrayList(动态数组)
ArrayList,即是动态数组,是一种按需动态调整大小的数组。数据访问时间为O(1)。一种典型的实现是在数组存满时将其扩容1.5倍((原始容量x3)/2 + 1)。
3 StringBuffer
通过观察上图StringBuffer的源代码,可以看到,StringBuffer的底层数据结构是一个字符型的数组。
通过观察上图的StringBuffer的构造方法,可以看出,初始StringBuffe默认底层数组容量为16,也可自己传一个容量,如果传一个字符串则为字符串的长度+16。它的容量增长规律为(容量+1)×2 。
1 散列表
何为散列表?官方给出的定义是一种能够将键(key)-映射为值(value)从而实现快速查找的数据结构。
我们接触比较多的HashMap就是对散列表的一种实现。
HashMap扩容:
初始容量默认是16,可以通过构造函数指定(指定后,其实也不是设置多少就是多少,他会是2的整数倍大于自己设置的值中的最小值),初始负载因子为0.75f,可以通过构造函数指定。极限值为负载因子*容量,默认初始为12。当使用容量大于等于极限值,容量倍增。如果倍增后的值大于最大容量1 << 30,则将桶大小修改为Integer.MAX_VALUE(1 << 31)。
2 ArrayList(动态数组)
ArrayList,即是动态数组,是一种按需动态调整大小的数组。数据访问时间为O(1)。一种典型的实现是在数组存满时将其扩容1.5倍((原始容量x3)/2 + 1)。
3 StringBuffer
通过观察上图StringBuffer的源代码,可以看到,StringBuffer的底层数据结构是一个字符型的数组。
通过观察上图的StringBuffer的构造方法,可以看出,初始StringBuffe默认底层数组容量为16,也可自己传一个容量,如果传一个字符串则为字符串的长度+16。它的容量增长规律为(容量+1)×2 。
相关文章推荐
- C/C++中的指针
- skynet
- hadoop的unknownhostexception
- JNI log来代替printf打印调试
- 分享一个网址
- C++ 11的新特性(初识)
- System Permissions—— android系统权限
- 简单的 Winsocket UDP 通信
- hdu CA Loves GCD(dp)
- 阿里巴巴Dubbo实现的源码分析(优秀)
- C++ Prime chapter.9 顺序容器性质(表)
- lua基础——安装使用以及helloworld
- css绝对定位
- Alibaba Dubbo框架同步调用原理分析-2
- iOS开发 ☞ NSString详解
- 多线程与单线程
- 在Elasticsearch中查询Term Vectors词条向量信息
- Alibaba Dubbo框架同步调用原理分析
- dubbo解析导读
- 二叉树的遍历