ABMultiValueCopyLabelAtIndex使用不当引起的内存泄漏
2016-01-06 15:17
495 查看
http://blog.sina.com.cn/s/blog_7309637a01016q6c.html
首先给一段错误的代码:
NSString *mm = (NSString*)ABMultiValueCopyValueAtIndex(phone, i);
mm = [mm substringToIndex:1];//这时的mm已经不是原先的mm了,之前的mm被内存泄漏了
if(mm)
CFRelease((CFTypeRef)mm);
//注:phone是由一下方式获取;ABMultiValueRef phone
= ABRecordCopyValue(person,kABPersonPhoneProperty);
上面这段代码使用xcode->product->Analyze编译会得到两个警告提示:、
(1)Incorrect decrement of the reference count of an object that is not owned at this point by the caller;
(2)Potential leak of an object allocated on line 414 and stored into 'mm'
接下来再给一段正确的代码:
CFStringRef mmcf = ABMultiValueCopyValueAtIndex(phone, i);
NSString *mm = (NSString*)mmcf;
mm = [mm substringToIndex:1];//mm由NSString的系统机制自行维护
CFRelease(mmcf);
最后,为什么会这样,Why?
我们分析一下那段错误的代码:
首先,将ABMultiValueCopyValueAtIndex(phone, i)得到的结果记作变量CF,
其类型是CFString。
CFString必须使用CFRelease()来释放,否则会内存泄漏;
(NSString*)CF是类型强制转换;把CF的内容以NSString*的形式提供出来。所以(NSString*)后,本质还是CF.
于是下面这句代码
NSString *mm = (NSString*)ABMultiValueCopyValueAtIndex(phone, i);
的真正含义是:
NSString *mm = (NSString*)CF;
此时,mm和CF本质上是同一个东东;
继续看接下来的代码:
mm = [mm substringToIndex:1];
将[mm substringToIndex:1]的结果记作变量B,于是上面的的语句也可以写作:
mm=B
这时产生问题了,CF哪里去了?按照这样写代码的方式,没有办法释放CF,所以CF即将被内存泄漏了。
于是在最后一句:
if(mm)
CFRelease((CFTypeRef)mm);
释放的的内容实际是B,不是原先的CF,CF被内存泄漏了。
首先给一段错误的代码:
NSString *mm = (NSString*)ABMultiValueCopyValueAtIndex(phone, i);
mm = [mm substringToIndex:1];//这时的mm已经不是原先的mm了,之前的mm被内存泄漏了
if(mm)
CFRelease((CFTypeRef)mm);
//注:phone是由一下方式获取;ABMultiValueRef phone
= ABRecordCopyValue(person,kABPersonPhoneProperty);
上面这段代码使用xcode->product->Analyze编译会得到两个警告提示:、
(1)Incorrect decrement of the reference count of an object that is not owned at this point by the caller;
(2)Potential leak of an object allocated on line 414 and stored into 'mm'
接下来再给一段正确的代码:
CFStringRef mmcf = ABMultiValueCopyValueAtIndex(phone, i);
NSString *mm = (NSString*)mmcf;
mm = [mm substringToIndex:1];//mm由NSString的系统机制自行维护
CFRelease(mmcf);
最后,为什么会这样,Why?
我们分析一下那段错误的代码:
首先,将ABMultiValueCopyValueAtIndex(phone, i)得到的结果记作变量CF,
其类型是CFString。
CFString必须使用CFRelease()来释放,否则会内存泄漏;
(NSString*)CF是类型强制转换;把CF的内容以NSString*的形式提供出来。所以(NSString*)后,本质还是CF.
于是下面这句代码
NSString *mm = (NSString*)ABMultiValueCopyValueAtIndex(phone, i);
的真正含义是:
NSString *mm = (NSString*)CF;
此时,mm和CF本质上是同一个东东;
继续看接下来的代码:
mm = [mm substringToIndex:1];
将[mm substringToIndex:1]的结果记作变量B,于是上面的的语句也可以写作:
mm=B
这时产生问题了,CF哪里去了?按照这样写代码的方式,没有办法释放CF,所以CF即将被内存泄漏了。
于是在最后一句:
if(mm)
CFRelease((CFTypeRef)mm);
释放的的内容实际是B,不是原先的CF,CF被内存泄漏了。
相关文章推荐
- iOS UISearchBar
- QtDesigner修改了ui文件后,程序运行不是修改后的内容。
- Java 基础之 String、StringBuilder、StringBuffer、CharSequence 区别
- IOS开发 把长度不等的UICollectionView 的cell 居左
- 关于UITableView的性能优化(历上最全面的优化分析) ...
- leetcode95 Unique Binary Search Trees II
- leetcode96 Unique Binary Search Trees
- BlockingQueue的使用
- 给UILabel中的文字加删除线
- Ubuntu Builder —— 一个制作自己的发行版的工具
- tasklet和workqueue的选择
- 将CodedUI Test 放到控制台程序中,模拟鼠标键盘操作
- 将CodedUI Test 放到控制台程序中,模拟鼠标键盘操作
- 关于xcode7.2以后 Build Settings Linking 默认没有 Other Linker Flags选项的解决方法
- IOS中UIScrollView的contentSize、contentOffset和contentInset属性
- UIImage 图片处理:截图,缩放,设定大小,存储
- iOS UIPageControl(分页控制器) 用法总结
- UIAlertView的简单用法
- UIImagePickerController本地化控件文字
- UITableViewCell - 4种显示格式