1,值類型對象有兩種表示形式:未裝箱和已裝箱,相反引用類型總是處於已裝箱形式 2,值類型從System.ValueType派生。該類型提供了與System.Object相同的方法。但是System.ValueType重寫了Equals方法,能在兩個對象的欄位值完全匹配的前提下返回true。此外,Sy ...
1,值類型對象有兩種表示形式:未裝箱和已裝箱,相反引用類型總是處於已裝箱形式 2,值類型從System.ValueType派生。該類型提供了與System.Object相同的方法。但是System.ValueType重寫了Equals方法,能在兩個對象的欄位值完全匹配的前提下返回true。此外,System.ValueType重寫了GetHashCode方法。生成哈希碼時,這個重寫方法所用的演算法會將對象的實例欄位中的值考慮在內。由於這個預設實現存在性能問題,所以定義自己的值類型時應重寫Equals和GetHashCode方法,並提供他們的顯示實現 3,由於不能將值類型作為基類型來定義新的值類型或者新的引用類型,所以不應在值類型中引入任何新的虛方法,所有方法都不能是抽象的,所有方法都隱式密封(不可重寫) 4,引用類型的變數包含堆中對象的地址。引用類型的變數創建時初始化為null,表名當前不指向有效對象。視圖使用null引用類型變數會拋出NUllReferenceException異常。相反,值類型的變數總是包含基礎類型的值,而且值類型的所有成員都初始化為0.值類型變數不是指針,訪問值類型不可能拋出NullReferenceExcption異常 5,將值類型變數賦值給另一個值類型變數,會執行逐欄位的賦值。將引用類型的變數賦值給另一個引用類型的變數只複製記憶體地址 6,兩個或多個引用能引用堆中的同一個對象,所以對一個變數執行的操作可能影響到另一個引用的對象。相反,值類型變數自成一體,對值類型變數執行的操作不可能影響另一個值類型變數 7,由於未裝箱的值類型不在堆上分配,一旦地定義了該類型的一個示例的方法不在活動,為他們分配的存儲就會被釋放,而不是等著進行垃圾回收