在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在C中定义的运算符,可以作用于类型或者某个实际的变量,并返回其在内存中的尺寸size_t. 在Cocoa中,我们一般用来将数组生成NSData的时候传入数据长度。因为在OC里面,sizeOf这个C运算符被保留了。 char bytes[] = {1, 2, 3}; NSData *data = [NSData dataWithBytes:&bytes length:sizeof(bytes)]; C中的sizeOf有两个版本,既可以接受类型,也可以接受某个具体的值。 sizeOf(int) sizeOf(a) 在Swift中,为了保证类型安全,sizeOf经过了一层包装,它不再是运算符,而是一个只能接受类型的方法。 我们还可以找到一个接受具体值,并返回尺寸的方法:sizeOfValue.这个方法返回的是Int,不是size_t。 var bytes:[CChar] = [1,2,3] sizeofValue(bytes) print(sizeofValue(bytes))----》8 虽然SizeofValue接受的是具体是,但是它和C的接收具体值的版本的sizeof行为并不相同。sizeofValue所返回的是这个值实际的大小,而并非其内容的大小。 如果我们在Swift中想表示上面的bytes的话,我们会将其类型写为CChar。在C或者OC中,对bytes做sizeof返回的是整个数组内容在内存中占据的尺寸。每个char为1,而数组元素为3,因此这个值是3.在Swift中,我们如果直接对bytes做sizeofValue操作的话,将返回8。 var bytes32:[CChar] = [1,2,3] print(sizeofValue(bytes32))
var bytes44:[CChar] = [1,2,3] let data = NSData(bytes: &bytes44, length: sizeof(CChar) * bytes44.count) print(data)
print(sizeof(UInt16)) print(sizeof(MyEnum)) print(sizeofValue(MyEnum.A)) print(sizeofValue(MyEnum.A.rawValue)) 2 1 1 2 没有咋看懂。 |
请发表评论