自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Linq String類型淺析

開(kāi)發(fā) 后端
這里介紹Linq String類型,發(fā)現(xiàn)我過(guò)去對(duì)String 的很多認(rèn)識(shí)都是錯(cuò)誤的,感覺(jué)這種錯(cuò)誤認(rèn)識(shí)還比較有典型性,于是寫(xiě)下此文和大家一起探討。

昨天調(diào)試一段程序發(fā)現(xiàn)內(nèi)存始終釋放不掉,最后終于發(fā)現(xiàn)是對(duì)String 的錯(cuò)誤使用造成,這促使我今天又仔細(xì)研究了一下Linq String類型,不研究不知道,一研究發(fā)現(xiàn)我過(guò)去對(duì)String 的很多認(rèn)識(shí)都是錯(cuò)誤的,感覺(jué)這種錯(cuò)誤認(rèn)識(shí)還比較有典型性,于是寫(xiě)下此文和大家一起探討。

1. Linq String類型變量追加,或修改后的新String對(duì)象是駐留(Interned)的。

我過(guò)去想當(dāng)然的認(rèn)為s2 是駐留的,但實(shí)際上并非如此,用 string.IsInterned 方法檢測(cè)s2是非駐留的。后來(lái)研究發(fā)現(xiàn)只有常量字符串才會(huì)默認(rèn)駐留,其他的字符串變量哪怕是采用 new string 構(gòu)造出來(lái)的,默認(rèn)都非駐留,除非用string.Intern 強(qiáng)行駐留。后面我將提到駐留對(duì)內(nèi)存的影響,微軟之所以不讓所有的字符串都駐留,我認(rèn)為還是處于內(nèi)存方面的考慮。

2. String 變量不再引用后CLR會(huì)通過(guò)GC自動(dòng)釋放其內(nèi)存。

  1. string s1 = "abcd";  
  2. s1 = null

上面代碼,我想當(dāng)然的認(rèn)為s1 = null 后已經(jīng)不再對(duì) "abcd" 這個(gè)字符串引用,如果沒(méi)有其他引用指向這個(gè)字符串,GC會(huì)釋放"abcd"這塊內(nèi)存。實(shí)際結(jié)果卻是否定的。因?yàn)閟1 被賦予了一個(gè)常量,導(dǎo)致 "abcd"這個(gè)字符串是駐留的,駐留的字符串在進(jìn)程結(jié)束之前無(wú)法被自動(dòng)釋放。更糟糕的是,我昨天調(diào)試的那段程序里面大量的字符串變量被采用 string.Intern 強(qiáng)制駐留,這導(dǎo)致我把所有的托管對(duì)象都釋放了依然無(wú)法釋放那部分大概30多M的內(nèi)存。

遺憾的是微軟的MSDN中文版中string.Intern 的幫助信息里面竟然漏掉了性能考諒(Performance consideration) 這一節(jié),我估計(jì)大多數(shù)中國(guó)程序員包括我在內(nèi)如果有中文的幫助是懶得去看英文的。很遺憾微軟中文的幫助不知道為什么把最重要的部分給漏了。

3. 兩個(gè)String如果引用不同只能用Equal 比較。

我一直想當(dāng)然的認(rèn)為 兩個(gè)Linq String類型如果用 == 操作符比較,將比較其引用。所以如果兩個(gè)String引用不同,則只能使用Equal 來(lái)比較它們是否相等。

【編輯推薦】

  1. LINQ to SQL數(shù)據(jù)表介紹
  2. LINQ查詢的目的與實(shí)現(xiàn)手段
  3. LINQ from子句進(jìn)行復(fù)合查詢實(shí)現(xiàn)方法
  4. LINQ查詢表達(dá)式功能詳解
  5. LINQ基礎(chǔ)概念總結(jié)
責(zé)任編輯:佚名 來(lái)源: 51CTO
相關(guān)推薦

2009-09-08 16:36:10

LINQ查詢基于泛型類

2009-09-15 14:30:11

Linq連接

2009-09-14 18:57:19

LINQ查詢

2009-09-17 13:30:32

LINQ to XML

2009-09-10 18:02:23

LINQ to SQL

2009-09-14 16:46:15

LINQ to XML

2009-09-16 17:11:35

LINQ To SQL

2009-09-16 15:33:22

LINQ to XML

2009-09-15 13:30:54

linq級(jí)聯(lián)

2009-09-14 13:37:25

LINQ ADO.NE

2009-09-10 14:47:53

Linq .NET查詢

2009-09-17 10:57:06

Linq隨機(jī)讀取數(shù)據(jù)

2009-09-17 17:34:23

linq to sql

2009-09-14 09:46:00

LINQ to SQL

2009-09-14 18:23:59

LINQ嵌套查詢

2009-09-17 18:05:15

linq to sql

2009-09-15 09:19:22

linq動(dòng)態(tài)條件

2009-09-15 10:12:37

LINQ To SQL

2009-09-01 16:35:55

C#操作String數(shù)

2009-09-15 17:16:58

LINQ查詢操作符
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)