标签:lin toolbar png 注意 archive 错误 tle logs .com
1> 没有存储不论什么内存地址的指针就称为空指针(NULL指针)
2> 空指针就是被赋值为0的指针。在没有被详细初始化之前。其值为0。
以下两个都是空指针:
1 Student *s1 = NULL; 2 3 Student *s2 = nil;
"野指针"不是NULL指针,是指向"垃圾"内存(不可用内存)的指针。野指针是很危急的。
接下来用一个简单的样例对照一下野指针和空指针的差别
1 Student *stu = [[Student alloc] init]; 2 3 [stu setAge:10]; 4 5 [stu release]; 6 7 [stu setAge:10];
执行程序。你会发现第7行报错了。是个野指针错误!
1> 运行完第1行代码后,内存中有个指针变量stu,指向了Student对象
Student *stu = [[Student alloc] init];
如果Student对象的地址为0xff43,指针变量stu的地址为0xee45。stu中存储的是Student对象的地址0xff43。即指针变量stu指向了这个Student对象。
2> 接下来是第3行代码
[stu setAge:10];
这行代码的意思是:给stu所指向的Student对象发送一条setAge:消息,即调用这个Student对象的setAge:方法。眼下来说。这个Student对象仍存在于内存中。所以这句代码没有不论什么问题。
3> 接下来是第5行代码
[stu release];
这行代码的意思是:给stu指向的Student对象发送一条release消息。在这里。Student对象接收到release消息后,会立即被销毁。所占用的内存会被回收。
(release的具体使用方法会放到OC内存管理中具体讨论)
Student对象被销毁了,地址为0xff43的内存就变成了"垃圾内存",然而。指针变量stu仍然指向这一块内存,这时候。stu就称为了野指针!
4> 最后运行了第7行代码
[stu setAge:10];
这句代码的意思仍然是: 给stu所指向的Student对象发送一条setAge:消息。可是在运行完第5行代码后。Student对象已经被销毁了,它所占用的内存已经是垃圾内存,假设你还去訪问这一块内存。那就会报野指针错误。这块内存已经不可用了,也不属于你了,你还去訪问它,肯定是不合法的。
所以。这行代码报错了。
1 Student *stu = [[Student alloc] init]; 2 3 [stu setAge:10]; 4 5 [stu release]; 6 7 stu = nil; 8 9 [stu setAge:10];
注意第7行代码,stu变成了空指针,stu就不再指向不论什么内存了
由于stu是个空指针。没有指向不论什么对象,因此第9行的setAge:消息是发不出去的,不会造成不论什么影响。当然。肯定也不会报错。
1> 利用野指针发消息是非常危急的,会报错。也就是说,假设一个对象已经被回收了,就不要再去操作它,不要再尝试给它发消息。
2> 利用空指针发消息是没有不论什么问题的,也就是说以下的代码是没有错误的:
[nil setAge:10];
标签:lin toolbar png 注意 archive 错误 tle logs .com
原文地址:http://www.cnblogs.com/yfceshi/p/7202493.html