芒果iOS开发之内存管理二
来源:互联网 发布:按键小精灵查看源码 编辑:程序博客网 时间:2024/04/28 10:29
/********** OC第十讲内存管理 **********/
主要内容
1.属性的内部实现原理
2.dealloc内释放实例变量
3.便利构造器方法的实现原理
4.collection的内存管理
/******* 1.属性的内部实现原理 ********/
/*
属性的语义设置以及使用范围
1.assign
2.retian
3.copy
*/
//把对象类型的属性语义设置成assign
//person1的引用计数为1
Person *person1 = [[Personalloc] init];
//sex的retainCount为1
NSString *sex = [[NSStringalloc] initWithFormat:@"%@",@"男"];
NSLog(@"sex.retainCount = %lu", sex.retainCount);
person1.gender = sex;//等价于 [person1 setGender:sex];
//对象在使用完之后就需要释放
[sex release];
//sex的retainCount为0,此时已被dealloc方法释放,再访问该对象就会引起野指针访问异常
NSLog(@"sex = %@", person1.gender);
[person1 release];
//把对象类型的属性语义设置成reatin
//person2的retaincount为1
Person *person2 = [[Personalloc] init];
//name此时的retaincount也是1
NSString *xingming = [NSStringstringWithFormat:@"%@",@"周杰伦"];
NSLog(@"xingming.retainCount = %lu", xingming.retainCount);
//person2的属性name语义关键字是retain,也就是会持有xingming,让xingming的引用计数又+1,此时xingming的retaincount为2
person2.name = xingming;
NSLog(@"xingming.retainCount = %lu", xingming.retainCount);
//当我们不需要的时候就释放自己得所有权。
[xingming release]; //release之后引用计数-1
NSLog(@"xingming.retainCount = %lu", xingming.retainCount);
//当person2释放的时候,会连带xingming的所有权也释放掉,此时xingming的引用计数变成0,会系统自动释放
[person2 release];
//打印结果
2015-11-16 11:14:28.251 OC-LessionTen[1170:51432] xingming.retainCount = 1
2015-11-16 11:14:28.251 OC-LessionTen[1170:51432] xingming.retainCount = 2
2015-11-16 11:14:28.251 OC-LessionTen[1170:51432] xingming.retainCount = 1
当person2释放的时候,同时释放掉xingming的所有权,那么xingming也会被释放掉。
- 芒果iOS开发之内存管理二
- iOS开发之内存管理
- iOS开发之内存管理
- iOS开发之内存管理
- iOS开发--内存管理之内存分配
- IOS开发学习之内存管理
- IOS开发之内存管理(2)
- (0048)iOS开发之内存管理探究
- iOS之内存管理
- iOS之内存管理
- IOS之内存管理
- V8之内存管理(二)
- ios学习之内存管理
- iOS学习之内存管理
- 高性能JAVA开发之内存管理(二)
- IOS开发(29)之内存管理(转载)
- IOS开发之内存管理--dealloc该写些什么
- iOS开发之内存管理:关于assign,retain和copy
- C. Wilbur and Points(简单贪心加合法性判断)
- 如何在脚本中获取进程ID(PID)
- 备份
- UIKit各类概述
- 手机自动化测试脚本命名规范
- 芒果iOS开发之内存管理二
- Ubuntu下安装MIPS交叉编译器 mips-linux-gcc
- JS 实现GOOGLE地图线路规划
- jetty 热部署
- 微信开发
- js 使用积累
- CSS学习<2>
- QT学习之QString的arg方法
- [leetcode] 142. Linked List Cycle II