C#中如何使用String對象,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
創(chuàng)新互聯(lián)長期為成百上千客戶提供的網(wǎng)站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為留壩企業(yè)提供專業(yè)的成都網(wǎng)站設計、成都網(wǎng)站建設,留壩網(wǎng)站改版等技術服務。擁有10年豐富建站經驗和眾多成功案例,為您定制開發(fā)。
把一個字符串變量賦給另一個字符串時,就會創(chuàng)建一個全新的C# String對象,就是說這個時候就會有兩個對象,比如:
classStringExc { publicstaticvoidMain() { strings1="originalstring"; strings2=s1;//注意此時會創(chuàng)建一個新對象 Console.WriteLine("s1is"+s1); Console.WriteLine("s2is"+s2); s1="changedstring"; Console.WriteLine("s1isnow"+s1); Console.WriteLine("s2isnow"+s2); } }
輸出結果為:
s1isoriginalstring s2isoriginalstring s1isnowchangedstring s2isnoworiginalstring
也就是說,改變s1的值并沒有對s2造成任何影響,這與我們平時所說的引用類型的行為正好相反。當用值"original string"初始化s1時,就在堆上分配了一個C# String對象。在初始化s2時,引用也指向這個對象,所以s2的值也是"original string"。但是現(xiàn)在要改變s1的值,而不是替換原來的值時,堆上就會為新值分配一個新對象。s2變量仍然指向原來的對象,所以它的值沒有改變。
另外,如果我們像下面這樣:
stringstr1="abc"; stringstr2="abc";
當我們用System.Object.Equals(str1,str2)比較時,返回值是true;按理說str1和str2應該指向不同的空間,應該返回false才對啊。原來Equals有三個版本:
publicoverrideboolEquals(object); publicboolEquals(string); publicstaticboolEquals(string,string);
前兩個實例方法內部會調用CompareOrdinal靜態(tài)方法,它會字符串中的各個字符,如果相等就返回true。第三個首先會檢查兩個引用指向的是否是同一個對象,如果是,就返回true,不再去比較各個字符了。
其實CLR使用了一種叫字符串駐留的技術,對于
string str1="abc"; string str2="abc";
當CLR初始化時,會創(chuàng)建一個內部的散列表,其中的鍵為字符串,值為指向托管堆中字符串的引用。剛開始,散列表為空,JIT編譯器編譯方法時,會在散列表中查找每一個文本常量字符串,首先會查找"abc"字符串,并且因為沒有找到,編譯器會在托管堆中構造一個新的指向"abc"的C# String對象引用,然后將"abc"字符串和指向該對象的引用添加到散列表中。
接著,在散列表中查找第二個"abc",這一次由于找到了該字符串,所以編譯器不會執(zhí)行任何操作,代碼中再沒有其它的文本常量字符串,編譯器的任務完成,代碼開始執(zhí)行。執(zhí)行時,CLR發(fā)現(xiàn)***個語句需要一個"abc"字符串引用,于是,CLR會在內部的散列表中查找"abc",并且會找到,這樣指向先前創(chuàng)建的C# String對象的引用就被保存在變量s1中,執(zhí)行第二條語句時,CLR會再一次在散列表中查找"abc",并且仍然會找到,指向同一個C# String對象的引用會被保存在變量s2中,到此s1和s2指向了同一個引用,所以System.Object.Equals(s1,s2)就會返回true了。
看完上述內容,你們掌握C#中如何使用String對象的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!