欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JAVA中StringBuffer与String的区别解析

程序员文章站 2024-02-22 12:16:53
看到这个讲解的不错,所以转一下 在java中有3个类来负责字符的操作。 1.character 是进行单个字符操作的, 2.string 对一串字符进行操作,不可变类...

看到这个讲解的不错,所以转一下

在java中有3个类来负责字符的操作。

1.character 是进行单个字符操作的,

2.string 对一串字符进行操作,不可变类。

3.stringbuffer 也是对一串字符进行操作,是可变类。

string:
    是对象不是原始类型.
    为不可变对象,一旦被创建,就不能修改它的值.
    对于已经存在的string对象的修改都是重新创建一个新的对象,然后把新的值保存进去.
string 是final类,即不能被继承.

stringbuffer:
    是一个可变对象,当对他进行修改的时候不会像string那样重新建立对象
    它只能通过构造函数来建立,
    stringbuffer sb = new stringbuffer();
注意:不能通过赋值符号对它进行付值.
sb = "welcome to here!";//error
对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向stringbuffer中赋值的时候可以通过它的append()方法.
sb.append("hello");

字符串连接操作中stringbuffer的效率要比string高:

string str = new string("welcome to ");
str += "here";
的处理步骤实际上是通过建立一个stringbuffer,然后调用append(),最后
再将stringbuffer tosting();
这样的话string的连接操作就比stringbuffer多出了一些附加操作,当然效率上要打折扣.

并且由于string 对象是不可变对象,每次操作sting 都会重新建立新的对象来保存新的值.
这样原来的对象就没用了,就要被垃圾回收.这也是要影响性能的.

看看以下代码:
将26个英文字母重复加了5000次,

复制代码 代码如下:

        string tempstr = "abcdefghijklmnopqrstuvwxyz";
        int times = 5000;
        long lstart1 = system.currenttimemillis();
        string str = "";
        for (int i = 0; i < times; i++) {
            str += tempstr;
        }
        long lend1 = system.currenttimemillis();
        long time = (lend1 - lstart1);
        system.out.println(time);

可惜我的计算机不是超级计算机,得到的结果每次不一定一样一般为 46687左右。
也就是46秒。
我们再看看以下代码
复制代码 代码如下:

        string tempstr = "abcdefghijklmnopqrstuvwxyz";
        int times = 5000;
        long lstart2 = system.currenttimemillis();
        stringbuffer sb = new stringbuffer();
        for (int i = 0; i < times; i++) {
            sb.append(tempstr);
        }
        long lend2 = system.currenttimemillis();
        long time2 = (lend2 - lstart2);
        system.out.println(time2);

得到的结果为 16 有时还是 0
所以结论很明显,stringbuffer 的速度几乎是string 上万倍。当然这个数据不是很准确。因为循环的次数在100000次的时候,差异更大。不信你试试

如果还是不能够明白:

1)string的联合+方法与stringbuff的append方法的区别:

string的+运算符在进行字符串运算时,首先将当前的字符串对象转换为stringbuff 类型,调用其append方法,最后再将生成的stringbuff 对象通过其tostring 方法转换为string类型的字符串,所以其效率要低。

但是在可读性上,还是string的连接运算符要高。

2)stringbuff是线程安全的

string是线程是非安全的

3)string是不可以修改的字符串对象,而stringbuff是可以修改的。

复制代码 代码如下:

public static boolean filecopy(string srcstr, string deststr) {

file srcfile = null;

file destfile = null;

reader reader = null;

writer writer = null;

boolean flag = false;

try {

srcfile = new file(srcstr);

if (!srcfile.exists()) {

system.out.println(“源文件不存在”);

system.exit(0);

} else {

reader = new filereader(srcfile);

}

destfile = new file(deststr);

writer = new filewriter(destfile);

char[] buff = new char[1024];

int len;

string str = “”;

stringbuffer sbuff = new stringbuffer();

while ((len = reader.read(buff)) != -1) {

//        str += new string(buff, 0, len);

sbuff.append(new string(buff,0,len));

}

//      writer.write(str.tochararray());

writer.write(sbuff.tostring().tochararray());

flag = true;

writer.flush();

reader.close();

writer.close();

} catch (ioexception e) {

system.out.println(“文件拷贝异常:= ” + e.getmessage());

}

return flag;

}