关于Objective-C 对象release操作的一个小问题探讨

简介:

 最近遇到这样一个问题,以前的时候并未注意;新建一个工程,然后添加一个类,文件结构是这样的

然后写了这样一小段程序,运行

 


 
 
  1. - (void)viewDidLoad   
  2. {   
  3.     [super viewDidLoad];   
  4.        
  5.     Test *testObj = [[Test alloc] init];   
  6.     NSLog(@"release 前 %d",[testObj retainCount]);   
  7.     [testObj release];   
  8.     NSLog(@"release 后 %d",[testObj retainCount]);   
  9.        
  10. }   

 

 

明明release了,retainCount计数应该为0,但是 为什么retainCount计数还是1,当我们release操作两次的时候程序就崩溃了;


然后我们打印一下testObj对象

 


 
 
  1. [cpp] view plaincopy 
  2. - (void)viewDidLoad   
  3. {   
  4.     [super viewDidLoad];   
  5.        
  6.     Test *testObj = [[Test alloc] init];   
  7.     NSLog(@"release 前 %d",[testObj retainCount]);   
  8.    
  9.     NSLog(@"testObj  release指向-->%@",testObj);   
  10.        
  11.     [testObj release];   
  12.    
  13.     NSLog(@"release 后 %d",[testObj retainCount]);   
  14.        
  15.     NSLog(@"testObj  release指向-->%@",testObj);   
  16.        
  17.        
  18. }   

 

 

发现他们指向同一块地址;

testObj 在alloc的时候在堆上申请到一片空间,然后它的retainCount计数为1,然后我们release之后,testObj指向的空间被销毁了,不存在了。此时testObj就是一个野指针了;此时我们调用[testObj retainCount]就属于一个不安全的做法;


然后我们在添加一行代码,[testObj release]之后,添加 testObj = nil;

 


 
 
  1. - (void)viewDidLoad   
  2. {   
  3.     [super viewDidLoad];   
  4.        
  5.     Test *testObj = [[Test alloc] init];   
  6.     NSLog(@"release 前 %d",[testObj retainCount]);   
  7.     NSLog(@"testObj  release指向-->%@",testObj);   
  8.     [testObj release];   
  9.     testObj = nil;   
  10.     NSLog(@"release 后 %d",[testObj retainCount]);   
  11.     NSLog(@"testObj  release指向-->%@",testObj);   
  12.        
  13.        
  14. }   

 

唉,看到这里就应该明白了吧,[testObj release] 后,testObj仍有指向,只是testObj原来指向的那片空间已被销毁,但是本身还存在,通过置为nil这一步操作,就不在指向原来那片地址;应该记起viewDidUnload函数作用了吧,它就是干这个活的,我们申明一个对象属性的时候,在viewDidUnload中将这个属性置为nil这一步操作;

 

     本文转自新风作浪 51CTO博客,原文链接:http://blog.51cto.com/duxinfeng/1170381,如需转载请自行联系原作者






相关文章
|
机器学习/深度学习 API iOS开发
【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词(一)
【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词(一)
184 0
|
存储 自然语言处理 Java
【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词(二)
【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词(二)
256 0
|
存储 供应链 编译器
玩转 Objective-C 的 Mock 对象
测试驱动开发(TDD)中,开发者经常使用模拟对象进行系统设计,模拟对象到底是什么呢?部分模拟对象和全部模拟对象又是什么呢?模拟对象真的让人又爱又恨吗?让我们以Objective-C测试框架OCMock来探个究竟。
216 0
|
iOS开发 C++
关于Objective-C 对象release操作的一个小问题探讨
来源:http://blog.csdn.net/duxinfeng2010/article/details/8757211 最近遇到这样一个问题,以前的时候并未注意;新建一个工程,然后添加一个类,文件结构是这样的 然后写了这样一小段程序,运行 [cpp] view pl...
677 0
|
7月前
|
安全 编译器 Swift
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
430 2
|
5月前
|
开发工具 iOS开发 容器
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
iOS Objective-C 应用连接Azure Storage时,若不关闭账号的匿名访问,程序能正常运行。但关闭匿名访问后,上传到容器时会出现错误:“Public access is not permitted”。解决方法是将创建容器时的公共访问类型从`AZSContainerPublicAccessTypeContainer`改为`AZSContainerPublicAccessTypeOff`,以确保通过授权请求访问。
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错