ARC下带CF前缀的类型与OC类型转换
Posted yuanxiaoping_21cn_com
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ARC下带CF前缀的类型与OC类型转换相关的知识,希望对你有一定的参考价值。
在对钥匙串操作时这个函数
OSStatus SecItemCopyMatching(CFDictionaryRef query, CFTypeRef * __nullable CF_RETURNS_RETAINED result)
经常用到,表示查询Keychain里是否有符合条件的记录。第一个参数查询条件,第二个查询到结果的引用。
在非ARC模式下的基本使用方法如下
NSData *passwordData = NULL;
if (SecItemCopyMatching((CFDictionaryRef)returnDictionary, (CFTypeRef *)&passwordData) == noErr){
//ToDo
}else{
//ToDo
}
这里需要把 &passwordData 转换为 CFTypeRef * 类型。而在ARC模式下 这样写会报错
Cast of an indirect pointer to an Objective-C pointer to ‘CFTypeRef *‘ (aka ‘const void **‘) is disallowed with ARC
要解决这个问题需要对ARC模式下CF类型与OC类型之间的转换有所了解,最常用的有两个转换关键字,(__bridge type)expression 和 (__bridge_transfer Objective-C type)expression。
(__bridge type)expression //type 为id 或者 void* , expression为带有CF前缀类型的变量或者 void* 变量。如下所示
1、id obj = [[NSObject alloc] init];
void *p = (__bridge void *)obj;
id o = (__bridge id)p;
2、CGImageRef cgimage
self.layer.contents = (__bridge id)cgimage;
(__bridge_transfer Objective-C type)expression //type为OC类型 expression 可以是带有CF前缀的类型变量 。
解决上面遇到的类型转换错误可以这样做
CFTypeRef passwordDataRef;
SecItemCopyMatching((CFDictionaryRef)returnDictionary, &passwordDataRef)
.........
NSData *passwordData = (__bridge_transfer NSData*)passwordDataRef;
这样转换之后再对passwordData 进行处理就不会报错了。
以上是关于ARC下带CF前缀的类型与OC类型转换的主要内容,如果未能解决你的问题,请参考以下文章
6.Swift协议|扩展|访问权限|异常调试|类型转换|运算函数|ARC|类类型初试化器|值类型初始化器