iOS -- 对自定义的其内存管理语义的 collection 使用无缝桥接(31)

对自定义的其内存管理语义的 collection 使用无缝桥接

OC 的系统库包含相当多的 collection 类, 其中有各种数组.各种字典,set,Foundation 框架定义了这些 collection 及其他各种 collection 所对应的 OC 类, 与之相似, CoreFoundation 框架也定义了一套 C语言的 API, 用于操作表示这些 collection 及其他的各种 collection 的数据结构, 例如: NSAraay 是 Foundation 框架中表示数组的 OC 类, 而CFArray 则是CoreFoundation 框架中的等价物,这两种创建数组的方式也许有区别, 然而,有一项强大的功能可以在这两个类型之间平滑转换, 它就是 '无缝桥接'.

使用 无缝桥接 技术,可以在定义与 Foundation 框架中的 OC 类 和 定义与 CoreFoundation 框架中的 C 数据结构之间互相装换,下面代码演示了简单的 无缝桥接

NSArray * anNSArray = @[@1,@2,@3];

CFArrayRef * aCFArray = (__bridge CFArrayRef)anNSArray;

NSLog(@"Size of array = %li",CFArrayGetCount(aCFArray));

转换操作中的 __bridge 告诉 ARC, 如何处理转换所涉及的 OC 对象. __bridge 本身的意思是: ARC 仍然具备这个 OC 对象的所有权, 而 __bridge_retained 则与之相反, 意味着 ARC 将交出对象的所有权, 若是前面那段代码改用它来实现, 那么用完数组之后要加上 CFRelease(aCFArray)以释放其内存,与之相似,反向转换可以通过 __bridge_transfer 来实现, 比方说,想把 CFArrayRef 转换为 NSArray, 并且想令 ARC 获得对象所有权,那么就可以采用此种转换方式.这三种转换方式称为 '桥式转换'

我们也许会问, 以纯 OC 来编写应用程序时,为何要用到这种功能呢? 这是因为: Foundation 框架中的 OC 类所具备的某些功能, 是 CoreFoundation 框架中的 C语言 数据结构 所不具备的,反之亦然,

CoreFoundation 框架中的字典类型叫做 CFDictionary ,其可变版本称为 CFMutableDictionary 创建 CFMutableDictionary 时,可以通过下列方法来指定 键 和 值 的内存管理语义.

CFMutableDictionaryRef CFDictionaryCreatMutable{

CFAllocatorRef allocator,

CFIndex capacity,

const CFDictionaryKeyCallBacks *keyCallBacks,

const CFDictionaryValueCallBacks *valueCallBacks

}

首个参数表示将要使用的内存分配器(allocator), CoreFoundation 对象里的数据结构需要占用内存, 而分配器负责分配及 回收这些内存, 开发者通常为这个参数 传入 NULL, 表示使用默认的分配器.

第二个参数定义了字典的初始大小, 它并不会限制字典的最大容量,只是向分配器提示了一开始应该分配多少内存, 假如要创建的字典含有 10 个对象, 那就向该参数传入 10.

最后两个参数定义了许多回调函数,用于指示字典中的键和值在遇到各种事件时应该执行何种操作.

你可能感兴趣的:(iOS -- 对自定义的其内存管理语义的 collection 使用无缝桥接(31))