java性能的优化(一)

subString内存泄漏问题

    sustring实现的方法为 new String(beginindex,count-endindex,value),当实际需要截取的值小于原本String的长度时并且string类型过长则可能数显内存泄漏,被截取字段中本身也包含了value值,因为String的构造函数为 :

String(...char value[]){

this.value=value;

...

}

解决方案:new String(str.subString(x,y))

split性能

    除了使用split进行切割以外 我们还可以使用其他的方法进行切割StringTokenizer 不过他本身需要调用nextToken方法跳到下一个点,性能上要优于split;

    当然我们也可以通过indexof实现类似的功能 相对其他而言效率上更加迅速

    indexof(高频率调用)>StringTokenizer >split

String循环体中添加数值

    在循环体重如果我们继续使用str+=str这样的方法会占用系统的内存,相加的本质是new Stringbuilder;因而在循环体中不断的实例化导致内存占用,此时使用循环为使用Stringbuilder将极大的提高性能

猜你喜欢

转载自blog.csdn.net/qq_24172179/article/details/80966895