Swift中的枚举有关联值。不一样枚举成员能够有不一样类型的关联值。bash
enum TestEnum {
case test0(a:Int,b:Int,c:Int)
case test1(a:Int,b:Int)
case test2(a:Bool)
case test3
}
复制代码
上边示例的枚举中有四个成员,其中前三个成员都关联有不一样类型和个数的关联值。能够经过如下方法来看TestEnum
类型的内存实际占用和内存分配ide
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。ui
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个字节)spa
前24个字节能够看出是3个关联值的内存,能够经过看其它成员值的内存布局来检查下第25个字节的用途。3d
总结: 枚举类型变量的内存占用能够解释为1个字节存储成员值(标明是哪一个成员),加上占用字节数最大的关联值的字节数。例如上边是(24 + 1),又因为内存对齐的原则,实际上分配的是32个字节。调试
若是没有关联值的话,那么内存只须要一个字节来存储是哪一个成员就够了。以下: code