虽然可能很明显,但我找不到答案。
我的问题是双重的。
想象一下,我有一个成员变量,直到需要时才初始化。我知道如果这个成员变量属于类类型,则成员变量的大小在初始化时将是int的大小,因为它只引用一个对象实例。
问题1是:未初始化的成员变量的大小是多少?我认为它很可能是相同的(int的大小)并且是某种空引用但我想问,因为我没有找到它。
问题2是:如果它是结构类型,那么该成员变量的大小是多少?如果未初始化,大小是多少?我的猜测是尺寸是sizeof('struct_type'),无论如何,我希望得到确认。
谢谢!
我想知道一个例子是否有助于为我澄清
public struct StructChild
{
public int One;
public int Two;
public int Three;
public int Four;
public int Five;
}
public class StructParent
{
public StructChild Child;
}
public class ClassChild
{
public int One;
public int Two;
public int Three;
public int Four;
public int Five;
}
public class ClassParent
{
public ClassChild Child;
}
在这个例子中,StructParent的大小是ClassParent的大小的5倍吗?
答案 0 :(得分:6)
我知道如果这个成员变量属于类类型,那么成员变量的大小在初始化时将是int的大小,因为它只引用一个对象实例。
不,你不知道,因为它是假的。
参考是32位进程中的32位和64位进程中的64位。 这就是我们称之为64位进程的原因。
引用只是32位进程中32位int的大小。
此处未初始化的成员变量的大小是多少?
首先,没有未初始化的成员变量这样的东西。内存分配器将所有成员变量初始化为其默认值。有未分配的成员变量,但C#中没有未初始化的成员变量。未分配的成员变量具有初始化的值:它是默认值。
其次,变量大小在分配时不会改变。引用类型的成员变量占用的存储量与一个引用一样多,无论它们是否已分配。
如果它是结构类型,该成员变量的大小是多少?
这是实现定义的。它取决于详细信息,例如结构成员的打包方式,以及是否存在任何布局属性。
用户定义类型T的我的猜测是尺寸是sizeof('struct_type')
sizeof(T)
仅适用于不安全代码,并且仅当结构是所有“非托管”类型时,如整数,指针类型等。
但是当它发挥作用时,是的,你可以依靠它来告诉你内存中有多大的东西。
请注意,编组程序的SizeOf会告诉您在编组边界上复制时的重要性,而不是在内存中有多大。
在这个例子中,StructParent的大小是ClassParent的大小的5倍吗?
没有。您忘记了作为引用类型实例的所有对象(包括盒装值类型)都有一个对象头。对象标头是两个引用的大小。
在32位机器上,我们期望StructParent的一个实例为其字段占用20个字节,为其头部占用8个字节,总共28个.ClassParent的实例占用头部8个字节,4个成员变量的字节总数为12,而不是28的五分之一。