Swift 的sizeof 和 sizeofValue
这篇讲的是从 C 过渡到 Swift 的开发者,在处理内存尺寸计算时需要注意的关键差异。文章从 C 语言中无处不在的 `sizeof` 运算符切入,指出它在 Swift 中被封装成了两个独立的方法:只能接受类型的 `sizeof` 和接受具体值的 `sizeofValue`。 最关键的区别在于 `sizeofValue` 的行为。它返回的并非像 C 那样的数组内容总大小,而是这个值本身(在 Swift 中往往是一个引用)的内存尺寸。作者用一个 `[CChar]` 数组的例子做了清晰对比:在 C 中 `sizeof(bytes)` 得到 3,而在 Swift 中 `sizeofValue(bytes)` 在 64 位系统下得到的是 8,这实际上是数组引用的长度。 文章接着指出了由此带来的实践影响:若要在 Swift 中像生成 `NSData` 时计算缓冲区大小,不能再直接使用 `sizeofValue`,而需要结合 `sizeof(CChar)` 和 `count` 属性进行手动计算。最后,文章通过一个关于枚举类型的练习题,引导读者深入思考 `sizeof` 与 `sizeofValue` 配合原始值时的不同表现,巩固对这一新模型的理解。