Core Foundation对象的内存管理

  • Foundation对象和Core Foundation对象重要的区别是ARC下的内存管理问题,在非ARC下两者都需要开发者手动管理内存,没有区别,但是在ARC下系统只会自动管理Foundation对象的释放,而不支持Core Foundation对象的管理,因此在ARC下两者进行转换后必须要确定对象是由开发者手动管理还是ARC系统管理,否则可能导致内存泄露
  • 由于ARC不能管理Core Foundation对象的生命周期,所以Core Foundation对象和Foundation对象转换时,需要使用到__bridge、__bridge_retained和__bridge_transfer三个转换关键字
  1. __bridge
    CFOC对象转化时只涉及对象类型,不涉及对象所有权的转化,他的含义是,不改变对象的管理权所有者,本来由ARC管理的Foundation对象,转换成Core Foundation对象后依旧由ARC管理,本来有开发者手动管理的Core Foundation对象转换成Foundation对象后,继续由开发者手动管理

  2. __bridge_transfer也可以使用CFBridgingRelease
    用在将Core Foundation对象转换为Foundation对象,同时将对象内存管理权交给ARC,由ARC来代替我们管理内存

  3. __bridge_retained也可以使用CFBridgingRetain
    用在将Foundation对象转换为Core Foundation对象,同时将对象内存管理权交给我们,后续需要使用CFRelease或者相关方法来释放对象,需要我们手动来管理内存

  • 如下例子为,网络请求中包含特殊字符的处理,报错信息为
    Error Domain=NSURLErrorDomain Code=-1002 "unsupported URL" UserInfo={NSLocalizedDescription=unsupported URL, NSUnderlyingError=0x7fa9b1d06120 {Error Domain=kCFErrorDomainCFNetwork Code=-1002 "(null)"}}
    1
    2
    3
    NSString * resultUrl = @"网络请求字段或者地址";
    // 处理请求中包含的特殊字符,如“+”
    NSString *endResutl = (__bridge_transfer NSString *)CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault, (CFStringRef)resultUrl, NULL, CFSTR("+"), kCFStringEncodingUTF8);
-------------本文结束感谢您的阅读-------------
最近的文章

iOS 后台运行方法

应用可以调用UIApplication的beginBackgroundTaskWithExpirationHandler方法,让应用最多有10分钟的时间在后台长久运行。这个时间可以用来做清理本地缓存、发送统计数据等工作。代码如下:1234567891011121314151617181920&#x2 …

继续阅读
更早的文章

CocoaPods安装与使用步骤详解

目录 CocoaPods安装过程 CocoaPods的使用 删除cocoapods已导入项目的第三方库和移除项目中的cocoapods CocoaPods安装过程 安装并载入rvm环境 打开终端,输入指令$ rvm -v 安装rvm安装指令是$ curl -L https://g …

继续阅读