Swift中枚举类型的内存占用

1,553 阅读2分钟

Swift中的枚举有关联值。不同枚举成员可以有不同类型的关联值。

enum TestEnum {
    case test0(a:Int,b:Int,c:Int)
    case test1(a:Int,b:Int)
    case test2(a:Bool)
    case test3
}

上边示例的枚举中有四个成员,其中前三个成员都关联有不同类型和个数的关联值。可以通过以下方法来看TestEnum类型的内存实际占用内存分配

print("TestEnum类型的内存占用:" + "\(MemoryLayout<TestEnum>.size)")
///TestEnum类型的内存占用:25  
print("TestEnum类型的内存分配:" + "\(MemoryLayout<TestEnum>.stride)")
///TestEnum类型的内存分配:32
print("TestEnum类型的内存对齐:" + "\(MemoryLayout<TestEnum>.alignment)")
///TestEnum类型的内存对齐:8

单独看一个TestEnum类型的变量的内存占用和分配

通过看枚举变量的内存地址来看内存里的数据是怎么存储的

断点调试右键要看的变量,点击如图选项进入:

看到图中红色圈出部分是t0变量关联值的存储方式,3个关联值每个都占用8个字节。

0A 00 00 00 00 00 00 00 //10
0B 00 00 00 00 00 00 00 //11
0C 00 00 00 00 00 00 00 //12
00 00 00 00 00 00 00 00 //成员值的存储0

注意:苹果的地址是小端模式。我们看到的是0A 00 00 00 00 00 00 00,实际读取的是00 00 00 00 00 00 00 0A。

On 32-bit platforms, Int is the same size as Int32, and on 64-bit platforms, Int is the same size as Int64. (在64位的机器中Int的size和Int64一样,64bit,8个字节)

前24个字节可以看出是3个关联值的内存,可以通过看其它成员值的内存布局来检查下第25个字节的用途。

可以看出第25个字节是用来标识是枚举类型的第几个成员值。t0是0,t1是1,t2是2,t3是3。

总结: 枚举类型变量的内存占用可以解释为1个字节存储成员值(标明是哪个成员),加上占用字节数最大的关联值的字节数。例如上边是(24 + 1),又由于内存对齐的原则,实际上分配的是32个字节。

如果没有关联值的话,那么内存只需要一个字节来存储是哪个成员就够了。如下: