重温C# clr 笔记总结
重溫C# clr 筆記總結(jié)
作者: 字體:[增加?減小] 類(lèi)型:轉(zhuǎn)載 時(shí)間:2013-05-13?我要評(píng)論
本篇文章是對(duì)以前學(xué)習(xí)C# clr做的一些筆記,現(xiàn)在拿出來(lái)和大家分享下,希望需要的朋友能參考一下1: .net framework 由兩個(gè)部分組成:CLR?和?FCL。
2:在CLR中,所有錯(cuò)誤都是通過(guò)異常來(lái)報(bào)告的。
3:智能感知功能主要是靠解析元數(shù)據(jù)實(shí)現(xiàn)的。
4:允許在不同語(yǔ)言之間方便的切換,并對(duì)各種語(yǔ)言進(jìn)行緊密集成是CLR的出色特性。
5:一個(gè)方法只有在首次運(yùn)行時(shí)才會(huì)由于jit造成一定的性能損失,以后對(duì)該方法的調(diào)用都以本地代碼的形式全速運(yùn)行。
?
6:方法簽名指定了參數(shù)的數(shù)量(及其順序),參數(shù)的類(lèi)型;方法是否有返回值,如果有返回值,還要指定返回值的類(lèi)型。
7:無(wú)論使用哪一種語(yǔ)言,類(lèi)型的行為是完全一致的,因?yàn)轭?lèi)型的行為最終由CLR的CTS來(lái)定義。
8:使用[assembly:CLSCompliant(true)] 來(lái)檢查CLS的相容性。
9:在同一程序集中,類(lèi)型默認(rèn)是internal,有一個(gè)原則是微軟總是選擇公開(kāi)程度最低的關(guān)鍵字,比如默認(rèn)的private。
10:在CLR中一個(gè)類(lèi)型的每個(gè)成員要么是一個(gè)字段,要么是一個(gè)方法。
?
11:應(yīng)答文件csc.rsp 的作用,使用/noconfig 開(kāi)關(guān)忽略局部和全局csc.rsp.
12:元數(shù)據(jù):二進(jìn)制數(shù)據(jù)塊,由幾張表構(gòu)成:分為3類(lèi):a:定義表,b:清單表,c:引用表。
13:一個(gè)托管的PE文件由4個(gè)部分構(gòu)成,PE32(+)頭,CLR頭,元數(shù)據(jù),IL。
14:程序集是一個(gè)或多個(gè)類(lèi)型定義文件及資源文件的集合。
15:程序集允許我們分離可重用類(lèi)型的邏輯和物理表示,如果一個(gè)程序集沒(méi)有用到,那么它將永遠(yuǎn)不會(huì)下載。
?
16:為了生成一個(gè)新的程序集,來(lái)自一個(gè)引用程序集的所有文件都必須存在,但運(yùn)行一個(gè)應(yīng)用程序時(shí),引用的程序集的所有文件不一定要全部存在。
17:程序集的版本號(hào)格式:主版本號(hào),副版本號(hào),Build號(hào),Revision號(hào)。
18:[assembly:AssemblyCulture(“de-ch”)] 將程序集的語(yǔ)言文化設(shè)置為瑞士德語(yǔ)。
19:使用msi文件可以實(shí)現(xiàn)“即需安裝”。
20:弱命名程序集之所有會(huì)成為問(wèn)題,是因?yàn)閹讉€(gè)不同的程序集可能具有相同的弱名稱(chēng)。
?
21:“Dll Hell” 根源:共享的Dll全部被復(fù)制到System32 目錄中,弱命名的名稱(chēng)可能相同,最后安裝的會(huì)覆蓋前面的程序集。
22:之所以能將程序集拖放進(jìn)GAC 依靠的是windows explorer shell (擴(kuò)展) shFusion.dll.
23:在命令窗口cmd下,進(jìn)入gac目錄 查看gac的結(jié)構(gòu)。
24:在安裝.net framework 時(shí),會(huì)安裝兩套副本,一套編譯器/CLR目錄,另一套:GAC 子目錄。
25:ToString 方法默認(rèn)反悔this.GetType().FullName.
?
26:GetType方法是非虛方法,這樣就可以防止一個(gè)類(lèi)重寫(xiě)該方法,隱瞞其類(lèi)型,破壞安全性。
27:命名空間和程序集沒(méi)什么關(guān)系。
28:堆上的所有對(duì)象都包含兩個(gè)額外的成員:類(lèi)型對(duì)象指針和同步塊索引。
29:System.Object 的GetType方法返回的是存儲(chǔ)在指定對(duì)象的“類(lèi)型對(duì)象指針”成員中的地址。
30:GetType方法返回的是指向?qū)ο蟮念?lèi)型對(duì)象的一個(gè)指針。
?
31:編譯器直接支持的任何數(shù)據(jù)類(lèi)型稱(chēng)為基元類(lèi)型。
32:在代表值類(lèi)型實(shí)例的一個(gè)變量中,并不包含一個(gè)指向?qū)嵗闹羔?#xff0c;相反變量中包含實(shí)例本身的字段。
33:文檔將所有值類(lèi)型都稱(chēng)為一個(gè)結(jié)構(gòu) 或一個(gè)枚舉。
34:假如知道自己寫(xiě)的代碼會(huì)造成編譯器反復(fù)對(duì)一個(gè)值類(lèi)型進(jìn)行裝箱,那么換用手動(dòng)方式對(duì)值類(lèi)型進(jìn)行裝箱,代碼會(huì)更小更快。
35:總結(jié)第34條:降低調(diào)用浪費(fèi)資源耗費(fèi)時(shí)間多的步驟的次數(shù)。
?
36:使用接口的方式可以允許我們更改一個(gè)已裝箱對(duì)象的字段,在C#中,不使用接口的方法是達(dá)到這個(gè)目的的。因?yàn)檫@個(gè)方式有點(diǎn)繞,所以不推薦使用需要修改字段的值類(lèi)型,在設(shè)計(jì)模式中,值類(lèi)型是不變的類(lèi)型。
37:在內(nèi)部,ValueType的Equals 方法使用反射技術(shù)來(lái)完成字段的比較,因?yàn)榉瓷浔容^慢,所以在定義自己的值類(lèi)型時(shí),應(yīng)重寫(xiě)Equals方法,不要調(diào)用base.Equals.具體的重寫(xiě)步驟如下:
a:如果obj == null –> false;
b: 參數(shù)引用不同對(duì)象? -> false;
c:每個(gè)字段都相等 –>check ->不相等(false)
d:true.
因?yàn)檎_的重寫(xiě)Equals 方法比較復(fù)雜,在性能要求不是很?chē)?yán)重的地方,可以不重寫(xiě)。
38:在需要修改一個(gè)哈希表的健值對(duì)時(shí),正確的做法是 先移除再添加。
39:不要對(duì)哈希碼 進(jìn)行持久化 ,因?yàn)楣4a很容易改變,例如一個(gè)未來(lái)的版本可能使用一個(gè)不同的算法來(lái)計(jì)算對(duì)象的哈希碼。
40:元數(shù)據(jù)的格式與源代碼所使用的編程語(yǔ)言無(wú)關(guān),因此元數(shù)據(jù)的格式都是相同的,元數(shù)據(jù)是所有語(yǔ)言都可以生成和使用的公共信息,是.net framework 開(kāi)發(fā)平臺(tái)的關(guān)鍵,它允許編程語(yǔ)言,類(lèi)型和對(duì)象之間無(wú)縫集成。
?
41:對(duì)于任何可訪問(wèn)的成員,都必須定義在一個(gè)可見(jiàn)的類(lèi)型內(nèi)。
PS:類(lèi)如果都看不到,你還能看到類(lèi)里面的東西嗎?
42:類(lèi)型的可見(jiàn)性:public??? internal(默認(rèn))
成員的可見(jiàn)性:public protected private (默認(rèn))
43:CLR要求接口的所有成員都是公開(kāi)的, 接口是個(gè)契約,是個(gè)合同,所以成員都公開(kāi)才有意義。
44:C# 編譯器要求原始成員和重寫(xiě)成員必須具有相同的可訪問(wèn)性,CLR 允許成員的可訪問(wèn)性約束更低,而不允許更高。如果父類(lèi)的某個(gè)方法是protected,那么子類(lèi)重寫(xiě)這個(gè)方法的時(shí)候,可以選擇約束更低的
public ,但是不能選擇約束更強(qiáng)的private。
44:關(guān)鍵字 static 僅僅可以應(yīng)用于類(lèi),不能應(yīng)用于值類(lèi)型(結(jié)構(gòu),枚舉),因?yàn)橹殿?lèi)型必須實(shí)例化,并且沒(méi)有辦法停止和阻止該過(guò)程。
45:靜態(tài)類(lèi)必須直接繼承 System.Object ,因?yàn)槔^承性?xún)H僅適用于對(duì)象。
?
46:靜態(tài)類(lèi)不能實(shí)現(xiàn)任何接口,因?yàn)橹挥惺褂妙?lèi)的實(shí)例才能調(diào)用接口的方法,可是靜態(tài)類(lèi)不能實(shí)例化。
47:只能定義靜態(tài)成員,因?yàn)殪o態(tài)類(lèi)不能實(shí)例化。
48:編譯器不會(huì)在靜態(tài)類(lèi) 類(lèi)型中生成實(shí)例構(gòu)造器方法。
49:C# 編譯器 完全支持部分類(lèi)(partial type) 特征,但是CLR 卻完全不支持,甚至CLR根本就沒(méi)有
partial關(guān)鍵字。
50:對(duì)于類(lèi)型字段:CLR 會(huì)在首次引用類(lèi)型時(shí)才創(chuàng)建動(dòng)態(tài)內(nèi)存,也即jit 編譯。
對(duì)于實(shí)例字段,創(chuàng)建類(lèi)型實(shí)例時(shí)才分配存放字段的動(dòng)態(tài)內(nèi)存。
?
51:如果一個(gè)字段屬于引用類(lèi)型,并且被標(biāo)記為readonly ,不可改變的是這個(gè)引用本身,而不是它所引用的對(duì)象。
52:構(gòu)造器是允許將類(lèi)型實(shí)例初始化為有效狀態(tài)的特殊方法。
53:如果有多個(gè)實(shí)例構(gòu)造器,最好通過(guò)this關(guān)鍵字先調(diào)用默認(rèn)無(wú)參構(gòu)造函數(shù),然后再賦值。
public SomeType(int x,int y):this(){}
54:所有值類(lèi)型的構(gòu)造器必須初始化值類(lèi)型的所有字段,因?yàn)橹殿?lèi)型的任何字段必須在讀取之前進(jìn)行初始化。
55:類(lèi)型構(gòu)造器 最多只有一個(gè),并且永遠(yuǎn)沒(méi)有參數(shù)。
?
56:因?yàn)镃LR保證每個(gè)應(yīng)用程序域的類(lèi)型構(gòu)造器只執(zhí)行一次,而且是線(xiàn)程安全的,所以最適合構(gòu)造
singleton 模式
57:如果希望應(yīng)用程序域關(guān)閉時(shí)能執(zhí)行某些代碼,我們可以在System.AppDomain的DomainUnload事件中注冊(cè)一個(gè)回調(diào)方法。
58:當(dāng)編譯器查找FCL 中的核心數(shù)值(Int32,Int64)等基元類(lèi)型的操作符時(shí),會(huì)生成直接操作的IL指令,所以核心FCL 類(lèi)型不能定義任何操作符重載方法的原因,因?yàn)榉椒ㄕ{(diào)用會(huì)影響效率。
59:CLR規(guī)范將轉(zhuǎn)換操作符重載方法定義為public 和static 方法。
60:只有方法的最后一個(gè)參數(shù)才可以使用params 關(guān)鍵字。
?
61:屬性不能作為out 或ref 參數(shù)傳遞給方法,字段則可以。因?yàn)閷傩缘谋举|(zhì)是getter 和 setter.
62:C# 編譯器 只允許接口定義方法,因?yàn)?事件,屬性,索引器 本質(zhì)上都是方法,所以也允許在接口中定義他們。
轉(zhuǎn)載于:https://www.cnblogs.com/liyancheng/p/5406579.html
總結(jié)
以上是生活随笔為你收集整理的重温C# clr 笔记总结的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: laravel在wamp中输入地址后总是
- 下一篇: Lua应用——tables应用,查找是否