public struct CustomerStruct
{
public string Name{get;set;}
}
代码非常简单,我们就定义一个struct类型,并且包含一个Name属性.

CustomerStruct customer = new CustomerStruct() ;
首先为什么对于数值类型也可以使用 new 来进行内存分配呢? 上面已经讲到,因为他们都是Class类型,当然可以使用new 来进行内存分配.
其次,CLR执行这样的代码的时,CLR 通过反射(有待考察)或者其他途径来获知所要请求分配内存的类型是否继承于System.ValueType如果是的话,那么就在栈上进行分配,如果不是的话,那么就是我们所说的引用类型,就在托管堆上分配内存以及栈上分配对应的引用变量,这些一切都是CLR做的工作.
我们再来看看装箱操作.
object o = new object();
Int32 aaa = 100;
o = aaa; //这里会发生装箱操作
我们都知道当CLR执行到 o = aaa;这条语句时会发生装箱操作,为什么会发生装箱操作呢?这是因为CLR 知道引用变量o所要引用的类型aaa是继承于System.ValueType类型的,继承于System.ValueType的类型都是在栈上分配的,而其它则是在托管堆上分配的,所以会CLR会弄得aaa的副本弄到托管堆上去,这一切也都是CLR的工作.
由此我们可以得出结论:
1.在C#中 就代码层面上讲 所有的类型都是Class类型.
2.所谓的 "值类型" != 数值类型,而是所有继承于System.ValueType 的类型.
3."值类型" 得到的语言级别的支持,CLR知道如何对 "值类型" 这样的Class类型进行内存分配和处理.
综上所述.个人愚见,有什么不对的地方希望大家帮忙指出,共同学习,共同进步.
最新相关文章
发表评论