string的用法
例子1
var str1 = "a"+1; //存在裝箱,效率低 string 是引用類型 數(shù)值是值類型
var str2 = "a" + 1.ToString();//效率更高
例子2
var str1 = "a";
str1 += "b";//又創(chuàng)建了2個(gè)字符串對(duì)象溉旋,并且執(zhí)行了一次string.Contact方法
var str2 = "a" + "b";//字符串不會(huì)在運(yùn)行時(shí)進(jìn)行拼接,而是會(huì)在編譯時(shí)直接生成一個(gè)字符串喊递,等效于 str="ab";效率更高
string s1 = "a";
string s2 = "b";
var str1 = s1 + s2;
var str2 = String.Format("字符1 {0}, 字母2 {1}", s1, s2);//效率高
例子3
string s1 = "a";
string s2 = "b";
var str1 = s1 + s2;
var str2 = String.Format("字符1 {0}, 字母2 {1}", s1, s2);//效率高
例子4
var str1 = "a";
str1 += "b";
str1 += "c";
str1 += "d";
//效率更高肯污,尤其是在處理大量字符串的時(shí)候或者是在循環(huán)里面
var str2 = new System.Text.StringBuilder("a");
str2.Append("b");
str2.Append("c");
str2.Append("d");
這樣寫法效率不高的原因:
- 裝箱
- 避免分配額外的內(nèi)存空間
- 使用“+”連接字符串
詳細(xì)解析
1.string 是屬于引類型 整數(shù)類型在與字符串進(jìn)行拼接操作時(shí),并不默認(rèn)調(diào)用ToString()方法,存在裝箱
2.string 它一旦被賦值就不可改變咆爽,所以“+”或者“=”都會(huì)在內(nèi)存中創(chuàng)建一個(gè)新的字符串對(duì)象霞赫,這也意味著要為該新對(duì)象分配新的內(nèi)存空間腮介。
3.String.Format是將指定的 String 類型的數(shù)據(jù)中的每個(gè)格式項(xiàng)替換為相應(yīng)對(duì)象的值的文本等效項(xiàng)。同樣端衰,我也可以用來(lái)拼接字符串叠洗,并且效率高于“+”
4.StringBuilder是可變長(zhǎng)度的,其首先在內(nèi)存中分配固定的長(zhǎng)度旅东,當(dāng)進(jìn)行頻繁的插入和連接操作時(shí)灭抑,超出了內(nèi)存中分配的長(zhǎng)度會(huì)自動(dòng)進(jìn)行擴(kuò)充,從而有效的節(jié)約了內(nèi)存空間和減少了生成對(duì)象的時(shí)間抵代。
腳本:
private float num = 2000;
private void Update()
{
Normal();
Test_1();
Test_2();
Test_3();
Test_4();
Test_5();
}
string s1 = string.Empty;
private void Normal()
{
Profiler.BeginSample("string++");
s1 = string.Empty;
for (int i = 0; i < num; i++)
{
s1 += i;
}
Profiler.EndSample();
}
StringBuilder stringBuilder_1=new StringBuilder();
private void Test_1()
{
Profiler.BeginSample("stringBuilder");
stringBuilder_1.Remove(0, stringBuilder_1.Length);
for (int i = 0; i < num; i++)
{
stringBuilder_1.Append(i);
}
Profiler.EndSample();
}
/// <summary>
/// string.Concat每次使用都會(huì)重新生成一個(gè)string腾节,然后對(duì)其進(jìn)行數(shù)據(jù)填充。
/// </summary>
private void Test_2()
{
Profiler.BeginSample("string.Concat");
string s1 = string.Concat("txt_pre_", Random.Range(0,100), "_end");
// Debug.Log(s1);
Profiler.EndSample();
}
/// <summary>
/// string.Format每次使用都會(huì)重新生成一個(gè)string荤牍,然后對(duì)其進(jìn)行數(shù)據(jù)填充案腺。
/// </summary>
private void Test_3()
{
Profiler.BeginSample("string.Format");
string s2 = string.Format("txt_pre_{0}_end", Random.Range(0, 100),"_end");
Profiler.EndSample();
}
/// <summary>
/// StringBuilder AppendFormat每次使用都會(huì)重新生成一個(gè)string,然后對(duì)其進(jìn)行數(shù)據(jù)填充参淫。
/// </summary>
StringBuilder stringBuilder_2 =new StringBuilder();
private void Test_4()
{
Profiler.BeginSample("StringBuilder.AppendFormat");
stringBuilder_2.Remove(0, stringBuilder_2.Length);
stringBuilder_2.AppendFormat("txt_pre_{0}_end", Random.Range(0, 100), "_end");
Debug.Log(stringBuilder_2);
Profiler.EndSample();
}
private void Test_5()
{
Profiler.BeginSample("string+num");
for (int i = 0; i < num; i++)
{
var str2 = "a" + i;
}
Profiler.EndSample();
Profiler.BeginSample("string+string");
for (int i = 0; i < num; i++)
{
var str2 = "a" + i.ToString();
}
Profiler.EndSample();
}
參考:
https://blog.csdn.net/onelei1994/article/details/101054633