国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

JAVA中StringBuffer與String的區別解析

2019-11-26 15:40:45
字體:
來源:轉載
供稿:網友

看到這個講解的不錯,所以轉一下

在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;

}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 定襄县| 海门市| 原阳县| 宾川县| 岐山县| 沅陵县| 沾益县| 绥江县| 开江县| 阜城县| 赫章县| 巴林右旗| 洛隆县| 额尔古纳市| 团风县| 北海市| 威远县| 贵德县| 上饶市| 镇赉县| 灵寿县| 临沧市| 登封市| 康平县| 图木舒克市| 托克逊县| 黄冈市| 三原县| 广宗县| 海林市| 通许县| 霍邱县| 南江县| 忻城县| 澄城县| 上林县| 山阴县| 房产| 娄烦县| 娄烦县| 永年县|