博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OC语言基础四:OC自动内存管理
阅读量:3731 次
发布时间:2019-05-22

本文共 665 字,大约阅读时间需要 2 分钟。

文章目录

自动引用计数:ARC,是我们Xcode默认支持的一种内存管理方式。
原则:
1.当使用一个强指针指向一个对象时,就会引起引用计数+1,这个指针就拥有了这个对象的绝对使用权。
2.如果没有任何强指针指向这个对象时,对象在出了最近的大括号(作用域),对象就会被立即释放。

重写dealloc方法,监听对象什么时候被销毁:

-(void)dealloc{//ARC下禁止调[super dealloc],系统会自动去调用这个方法   NSLog(@"person<%p>",被销毁)}

在ARC下,如果前面不添加任何关键词,我们系统就会将我们的对象指针默认视为强指针:

Person *person=[[Person alloc]init];

弱指针:在前面添加弱引用标准,__weak,两个下划线。

对象一被创建就会被立即销毁,在接下来的使用当中是无法使用这个对象的。不会引起引用计数加1。只要出了作用域立即被销毁。

Person __weak *person1=[[Person alloc]init];

可以这样使用:person2指向person相同的对象,并不是对象创建。

Person __weak *person2=person;

__unsafe_unretained:一般情况不要去使用,因为去使用它,可能导致内存访问的不安全现象。也是用来表示弱引用的相当于assign,这是简单的完成了对象地址的复制。它和weak的区别:weak当对象释放的时候,相应的指针变量被置为nil,而assign并不会这样去做。

转载地址:http://hpwin.baihongyu.com/

你可能感兴趣的文章
关于时序数据流经Kafka之后可能产生乱序的原因和解决方法
查看>>
flink以gz格式写入hdfs
查看>>
解决Mysql连接8小时空闲失效问题
查看>>
flink配合druid连接池的使用
查看>>
博主带你深入理解JVM
查看>>
23种设计模式前言
查看>>
设计模式之单例模式和工厂模式
查看>>
flink state TTL(Time To Live) 如何应对飞速增长的状态?checkpoint机制原理?
查看>>
那些年,我们一起使用过的case...when
查看>>
flink之内存分配与内存管理
查看>>
一篇由flink akka timeoutException引发的slot和parallelism
查看>>
flink批量(batch)写入mysql/oracle
查看>>
基于flink broadcast实现目标用户的智能筛选
查看>>
Apache Hbase基本概念及Java API
查看>>
flink table & sql(一)table基础概念、环境搭建、source、sink
查看>>
flink table & sql(二)tableAPI
查看>>
flink之Timer定时器
查看>>
hive开启动态分区,文件压缩
查看>>
flink之TTL(Time To Live),State Backend,How to Clear State?
查看>>
flink之Operator State(non-keyed state)
查看>>