偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Linq String類型淺析

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

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

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

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

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

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

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

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

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

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

【編輯推薦】

  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é)任編輯:佚名 來源: 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級聯(lián)

2009-09-10 14:47:53

Linq .NET查詢

2009-09-14 13:37:25

LINQ ADO.NE

2009-09-17 17:34:23

linq to sql

2009-09-17 10:57:06

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

2009-09-15 09:19:22

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

2009-09-15 10:12:37

LINQ To SQL

2009-09-14 09:46:00

LINQ to SQL

2009-09-17 18:05:15

linq to sql

2009-09-14 18:23:59

LINQ嵌套查詢

2009-09-10 10:09:46

LINQ to SQL

2009-09-11 09:22:14

System.Linq
點(diǎn)贊
收藏

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