125.请介绍C#中的堆
堆是从下往上分配,所有已用空间在自由空间的下面。C#中所有引用类型对象分配在托管堆上,托管堆在内存中是连续分配的,并且内存对象的释放受垃圾收集机制管理,效率相对于栈来说低许多。
126.请介绍C#中的堆栈
在C#中,堆栈(stack)实际上是自上向下进行填充,即由高内存地址向地内存地址填充,并且堆栈的分配都是连续的。C#中的所有值类型对象和引用类型对象的引用都分配在堆栈上,堆栈根据对象的先进后出原则,一次分配和释放内存对象。堆栈根据一个指向栈尾的指针来分配内存,执行效率较高。
127.C#中的堆和堆栈有什么区别
堆是从下往上分配,所以已用空间在自由空间的下面。堆栈实际上是自上向下进行填充。堆的执行效率对于堆栈来说低许多。在C#中,栈具有自我维护性,栈的内存管理可以通过操作系统来完成。而堆的管理就需要通过GC来完成,使用一定的算法来扫描并释放冬眠的对象。
128.C#中的深拷贝与浅拷贝的区别
深拷贝是指源对象与拷贝对象相互独立,其中任何一个对象的改动都不会对另外一个对象造成影响。浅拷贝是指将对象中的数值类型的字段拷贝到新的对象中,而对象中的引用型字段则仅复制它的一个引用到目标对象。无论深拷贝与浅拷贝的实现,都可以通过实现ICloneable接口Clone()方法来实现。深拷贝与浅拷贝最大的区别就是对于对象引用成员的处理。