String、StringBuffer、StringBuilder的區別
String、StringBuffer、StringBuilder的區別
理論(這幾個東西的區別是啥?)---先不說話我們先上代碼,不管懂不懂,先照抄!
package com.sandy;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import java.util.Iterator;
/**
* Created by alittlefish on 2017/8/17.
*/
public class StringCompare {
public static void main(String[] arg) {
try {
Integer count = 7000;
String content = "[\n" +
"{\n" +
"\"moduleId\":3,\n" +
"\"moduleName\":\"測試板塊\",\n" +
"\"moduleTitle\":\"測試板塊\",\n" +
"\"moduleData\":{\n" +
"\"startDate\":\"2017-06-26\",\n" +
"\"endDate\":\"2017-06-26\"\n" +
"},\n" +
"\"moduleHtml\":\"DateRange\",\n" +
"\"moduleType\":1,\n" +
"\"moduleSort\":0,\n" +
"\"moduleObsolete\":0,\n" +
"\"moduleImage\":\"https://sandy.com/%E5%B7%A5%E6%9C%9F.png%2Forigine%2F37c6bb95-efee-4f7c-9b07-2df0051c5137?imageMogr2/auto-orient/strip/quality/90\"\n" +
"},\n" +
"{\n" +
"\"moduleId\":188,\n" +
"\"moduleName\":\"測試板塊描述\",\n" +
"\"moduleTitle\":\"測試板塊描述\",\n" +
"\"moduleData\":{\n" +
"\"moduleDesc\":\"StringBuilder板塊\",\n" +
"\"content\":\"aontent\",\n" +
"\"files\":[\n" +
"]\n" +
"},\n" +
"\"moduleHtml\":\"ConsultContent\",\n" +
"\"moduleType\":1,\n" +
"\"moduleSort\":0,\n" +
"\"moduleObsolete\":0,\n" +
"\"moduleImage\":\"https://sandy.com/%E9%A1%B9%E7%9B%AE%E6%8F%8F%E8%BF%B0.png%2Forigine%2F9a079c77-3eca-44d2-905b-90e95cb6bd2b?imageMogr2/auto-orient/strip/quality/90\"\n" +
"}]";
content = "{result:" + content + "}";
JSONObject object = JSONObject.parseObject(content);
JSONArray array = object.getJSONArray("result");
Iterator<Object> iterator = array.iterator();
StringBuffer result = new StringBuffer();
StringBuilder result1 = new StringBuilder();
String result2 = new String("aontent");
while (iterator.hasNext()) {
JSONObject ob = (JSONObject) iterator.next();
if (ob.getString("moduleName").equals("測試板塊描述")) {
JSONObject re = ob.getJSONObject("moduleData");
result = result.append(re.getString("content"));
result1 = result1.append(re.getString("content"));
}
}
result.replace(0, 1, "c"); //把位置0到0(也就是a)換成c
Long pre = System.currentTimeMillis();
String addTest = ":test";
for (int i = 0; i < count; i++) {
result.append(addTest); //添加7000次比較添加時間
}
Long now = System.currentTimeMillis();
result.append(addTest); //添加字符串"test"
result1.replace(0, 1, "c"); //把位置0到0(也就是a)換成c
Long pre1 = System.currentTimeMillis();
String addTest1 = ":test";
for (int i = 0; i < count; i++) {
result1.append(addTest1); //添加字符串"test1"
}
Long now1 = System.currentTimeMillis();
result2.replace('a', 'c'); //將裏麵的a全部替換成c
Long pre2 = System.currentTimeMillis();
String addTest2 = ":test";
for (int i = 0; i < count; i++) {
result2 = result2 + addTest2;
}
Long now2 = System.currentTimeMillis();
System.out.println("StringBuffer拚接字符串時間:" + String.valueOf(now - pre) + "-----result:" + result2);
System.out.println("StringBuilder拚接字符串時間:" + String.valueOf(now1 - pre1) + "-----result1:"+result1);
System.out.println("String拚接字符串時間:" + String.valueOf(now2 - pre2) + "-----result2:"+result2);
// System.out.println(StringCompare.modify("abc"));
} catch (Exception e) {
e.printStackTrace();
}
}
private static String modify(String greeep) {
String update = greeep.substring(1, 3);
return update + "p!";
}
}
結果:
好了上麵對著上麵的運行結果,我們來聊5毛錢的區別
區別
- String:Strings are constant(字符串常量、線程安全);
- StringBuffer:A thread-safe, mutable sequence of characters(字符串變量、線程安全);
- StringBuilder:A mutable sequence of characters(字符串變量、線程不安全)。 ####劃重點,由上麵的運行時間和最後的字符串result,可以看出:
- 運行時間: StringBuilder<StringBuffer<String;
- ACID原則 :StringBuffer、String的內容沒變,SttingBuilder改變
因此如果是單線程處理較短的字符串建議使用字符構建器:StringBuilder,多線程使用StringBuffer,StringBuilder、StringBuffer就是為構建字符串而生,其餘建議String
源代碼
看源代碼,反正我是把這三個類看了滴。
String的優點是:編譯器可以讓字符串字符共享。
java字符串中的字符是不可以修改的,例如:result = "acontent"字符串"acontent"永遠包含a、c、o、n、t、e、n、t代碼單元。但是字符變量result是闊以修的。
你可以想象各種字符串存放在公共的存儲池中(如果看過編譯原理應該很好理解,寫C的大佬們總把字符串理解為字符類型的數組),字符串變量指向存儲池中相應的位置。如果複製一個字符串變量,原始的字符串將和複製的共享字符串。
常用方法、使用
JDK5.0中引入了StringBuilder,前身是StringBuffer,所以我們對比String和StringBuffer的方法。
相同
- 這兩個類都是用來處理字符串的的,都提供了length()、toString()、charAt()、subString()方法,並且在兩個類中用法相同。
- 字符在字符串中的索引位置都是從0開始。
不同
- String類的subString()、concat()、toLowerCase()、toUpperCase()、trim()等方法都不會改變字符串本身,而是創建一個新的包含改變後的新的字符串對象;StringBuffer類的append()、replaceAll()、replaceFirst()、insert()、setCharAt()等方法都會改變字符緩衝區中字符串內容。
- String類涵蓋Object類的equals()方法,StringBuffer類不包含。
- String類字符串拚接闊以直接用"+"StringBuffer類say no!
- 兩個類都覆蓋了Object的toString()方法但是實現卻不同,String類中的返回當前Strings實例本身的引用,StringBuffer類返回以當前緩衝區的所有字符為內容的新String對象的引用
最後更新:2017-09-26 09:32:47