为什么StringBuilder的效率要比String高?

 先看一个例子:

为什么StringBuilder的效率要比String高?_第1张图片标题

从上面的例子可以看到,StringBuilder的运行时间只有简单字符串拼接的千分之一 ,那是什么原因造成的呢?

String在java中是不可变长的,一旦初始化就不能修改长度,简单的字符串拼接其实是创建新的String对象,再把拼接后的内容赋值给新的对象,在频繁修改的情况下会频繁创建对象,而StringBuilder则不会,从头到尾只有一个实例对象,那StringBuilder是怎么实现的呢?

 其实StringBuilder在append时并不是用String存储,而是放到一个value的char数组中,字符串是固定长度的,而数组是可以扩容的,这样就不需要不停创建对象了

为什么StringBuilder的效率要比String高?_第2张图片

 那StringBuilder中数组的初始长度是多少呢?扩容系数是多少呢?

数组默认的初始长度是16,也可以根据构造方法指定

扩容系数: value.length * 2 + 2,而且只有当append是数据长度+value.count > value.length时才会扩容一次,不会每次都扩容去调用Arrays.copyof()

为什么StringBuilder的效率要比String高?_第3张图片为什么StringBuilder的效率要比String高?_第4张图片

 为什么StringBuilder的效率要比String高?_第5张图片

为什么StringBuilder的效率要比String高?_第6张图片

你可能感兴趣的:(java)