我们都知道Java中的HashMap是使用数组,结合链表来实现的,其结构如下:
如果加入的元素数量达到了设定的阈值,那么必然会涉及到扩容重新分配空间,将元素重新插入到新的空间中,也就是发生了rehash。这个过程其实是很耗时的,这也是为什么我们写代码时,最好指定的HashMap的初始空间大小的原因,就是为了避免或者减少发生rehash的次数。下面我们来看看这个过程的具体实现。
JDK是一直在升级的,其中的代码也在不断优化调整,我们这次主要就看下JDK1.7
和 JDK1.8
中的实现
我们都知道Java中的HashMap是使用数组,结合链表来实现的,其结构如下:
如果加入的元素数量达到了设定的阈值,那么必然会涉及到扩容重新分配空间,将元素重新插入到新的空间中,也就是发生了rehash。这个过程其实是很耗时的,这也是为什么我们写代码时,最好指定的HashMap的初始空间大小的原因,就是为了避免或者减少发生rehash的次数。下面我们来看看这个过程的具体实现。
JDK是一直在升级的,其中的代码也在不断优化调整,我们这次主要就看下JDK1.7
和 JDK1.8
中的实现
这篇来跟踪一下AbstractBeanFactory#getBean(java.lang.String, java.lang.Class<T>)
这个方法获取bean实例的流程,由于过程比较复杂,我们这里以一个简单的例子来跟进一下主要的流程
下面我们看下具体的例子代码
spring配置文件
1 | <?xml version="1.0" encoding="UTF-8"?> |
spring-beans虽然是一个很基础的包,但是它已经包括了很多的功能,我们先看下如何在只使用spring-beans包的情况下,解析并拿到xml中配置的bean实例
spring-bean.xml
1 | <?xml version="1.0" encoding="UTF-8"?> |
解析代码
1 | // 1.创建一个BeanFactory |
MyBatis是我们常用的ORM框架,先看一下它的基本用法(省略了Mapper相关的配置项):
1 | // 读取MyBatis配置文件 |
工作中最常用的还是与Spring结合,使用mybatis-spring
1 | <dependency> |
CountDownLatch功能很简单,它主要有两个方法,await()
与countDown()
,初始创建的时候需要给它提供一个数值,调用countDown()
方法会将数值减1,调用await()
方法的时候会判断值是不是等于0,如果等于0就继续执行,否则就阻塞等待
1 | // 初始化创建,值为1 |
利用这两个方法,我们能用来做什么呢?
Redis支持的主要有5种数据类型,string
, list
, set
, zset
, hash
,但是对于每种数据类型,Redis都不是简单的使用一种数据结构来实现,而是根据数据量等因素使用多种数据结构(SDS、双向链表、hashtable等),来达到提高效率、节省空间的目的,可以使用object encoding <key>
来查看数据的内部结构
聚合的目的是为了快速构建项目,当我们有几个maven模块,想要一次性构建,而不是到每个模块下面去执行maven命令,这时候就需要使用maven聚合(或者称为多模块)。
使用聚合的时候,我们需要新建一个maven项目,由它来控制构建其他的项目,其pom.xml配置与其他普通maven项目的区别主要在以下两个地方:
这样当我们在此项目下执行构建的时候,就会同时构建其中配置的项目。
将元素添加到数组尾部
1 | var values = [1,2,3,4,5] |
将数组尾部元素弹出
1 | var values = [1,2,3,4,5] |
弹出数组头元素
1 | var values = [1,2,3] |
ECMAScript中有五种基本数据类型:Undefined
, Null
, Boolean
, Number
, String
,一种复杂数据类型:Object
typeof
函数,例:
1 | var s = xx; |
返回结果=typeof(res) | 意义 |
---|---|
typeof(res) === “undefined” | 值未定义 |
typeof(res) === “boolean” | 值为布尔类型 |
typeof(res) === “string” | 值是字符串 |
typeof(res) === “number” | 值为数值 |
typeof(res) === “object” | 值是对象或null |
typeof(res) === “function” | 值是函数 |