关于Objective-C 对象release操作野指针的一个小问题探讨
2013-04-09 17:25
591 查看
最近遇到这样一个问题,以前的时候并未注意;新建一个工程,然后添加一个类,文件结构是这样的
然后写了这样一小段程序,运行
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
[testObj release];
NSLog(@"release 后 %d",[testObj retainCount]);
}
明明release了,retainCount计数应该为0,但是 为什么retainCount计数还是1,当我们release操作两次的时候程序就崩溃了;
然后我们打印一下testObj对象
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
[testObj release];
NSLog(@"release 后 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
}
发现他们指向同一块地址;
testObj 在alloc的时候在堆上申请到一片空间,然后它的retainCount计数为1,然后我们release之后,testObj指向的空间被销毁了,不存在了。此时testObj就是一个野指针了;此时我们调用[testObj retainCount]就属于一个不安全的做法;
然后我们在添加一行代码,[testObj release]之后,添加 testObj = nil;
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
[testObj release];
testObj = nil;
NSLog(@"release 后 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
}
唉,看到这里就应该明白了吧,[testObj release] 后,testObj仍有指向,只是testObj原来指向的那片空间已被销毁,但是本身还存在,通过置为nil这一步操作,就不在指向原来那片地址;应该记起viewDidUnload函数作用了吧,它就是干这个活的,我们申明一个对象属性的时候,在viewDidUnload中将这个属性置为nil这一步操作;
然后写了这样一小段程序,运行
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
[testObj release];
NSLog(@"release 后 %d",[testObj retainCount]);
}
明明release了,retainCount计数应该为0,但是 为什么retainCount计数还是1,当我们release操作两次的时候程序就崩溃了;
然后我们打印一下testObj对象
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
[testObj release];
NSLog(@"release 后 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
}
发现他们指向同一块地址;
testObj 在alloc的时候在堆上申请到一片空间,然后它的retainCount计数为1,然后我们release之后,testObj指向的空间被销毁了,不存在了。此时testObj就是一个野指针了;此时我们调用[testObj retainCount]就属于一个不安全的做法;
然后我们在添加一行代码,[testObj release]之后,添加 testObj = nil;
[cpp] view
plaincopy
- (void)viewDidLoad
{
[super viewDidLoad];
Test *testObj = [[Test alloc] init];
NSLog(@"release 前 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
[testObj release];
testObj = nil;
NSLog(@"release 后 %d",[testObj retainCount]);
NSLog(@"testObj release指向-->%@",testObj);
}
唉,看到这里就应该明白了吧,[testObj release] 后,testObj仍有指向,只是testObj原来指向的那片空间已被销毁,但是本身还存在,通过置为nil这一步操作,就不在指向原来那片地址;应该记起viewDidUnload函数作用了吧,它就是干这个活的,我们申明一个对象属性的时候,在viewDidUnload中将这个属性置为nil这一步操作;
相关文章推荐
- 关于Objective-C 对象release操作的一个小问题探讨
- 关于Objective-C 对象release操作的一个小问题探讨
- 关于Objective-C 对象release操作的一个小问题探讨
- 关于Objective-C 对象release操作的一个小问题探讨
- 关于Objective-C 对象release操作的一个小问题探讨
- 关于Objective-C 对象release操作的一个小问题探讨
- oc 关于对象release后 指向它的指针如何处理的问题
- 关于C语言的文件型指针和移位操作中的一些有趣问题的探讨
- 一次ORA-4030问题诊断及解决【解决思路不错,说明了对象的统计信息与优化器的优化操作(即选择执行一个SQL语句在该优化参数环境下最佳的执行计划)间的关系】
- 关于在2个界面上操作数据库中同一个表的问题,
- C++中一个关于复制构造函数和指针的问题
- 【原】函数返回一个指针以及返回STL对象的问题
- 关于ASP.NET“操作必须使用一个可更新的查询”问题的解决方法
- 关于 将一个数组赋值给另外一个数组会重置原来数组的指针 的问题
- solr中一个问题——顺便讨论java中关于中包括main函数以及涉及资源(变量)操作中的类
- JS中关于带操作赋值的一个小问题
- 今天遇到一个关于对象和对象方法内存分配的有趣的问题
- Linux内核中关于数据结构操作的一个问题
- 详解JavaScript对Date对象的操作问题(生成一个倒数7天的数组)
- 最近写一个C#关于U盘的操作,在弹出U盘是遇到了些问题,C#调WINdoWs底层的东西太麻烦了,看样子要看看VC或C了