Swift 内存管理

Swift 中使用自动引用计数(ARC)机制来追踪和管理内存

强引用strong和无主引用unowned

通过阅读源码我们知道Swift中的class底层继承于HeapObject,它有个refCounts的属性,refCounts本质是一个Uint_64_t类型,该属性记录了strong和unowned等信息。

islmmortal (0位)
unownedRefCount (1-31位):无主引用
isDeinitingMask (32位):是否正在进行释放
strongExtraRefCount (33-62位):强引用计数
useSlowRC (63位)

image.png

我们可以看到,强引用0、无主引用1

但是通过CFGetRetainCount打印输出是2
原因是 CFGetRetainCount会在执行前,先进行strong_retain操作,在执行后,完成release_value操作。
所以swift中CFGetRetainCount打印的强引用计数,会比原引用计数多1

弱引用


我们可以看到引用计数是没有变化的,但是内存地址变的有些奇怪。
本质是weak关键字在底层创建了一个HeapObjectSideTableEntry的对象也就是散列表,并将散列表的地址放到了refCounts上。
HeapObjectSideTableEntry的对象包含HeapObject中的信息,还增加了一个uint32_t的属性,用来放弱应用的信息,并且为可选类型
散列表地址=refCounts清楚63、62位 + 左移3位

总结
对于HeapObject来说,其refCounts 有两种

  • 无弱引用:strongCount + unownedCount
  • 弱引用:obct+xxx+(strongCount + unownedCount)+weakCount
HeapObjectSideTableEntry{
        HeapObject *object
        xxx
        strong Count + unowned Count(uint64_t)//64位
        weak count(uint32_t)//32位
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一. 关于引用 跟OC一样,Swift也是采取基于引用计数的ARC内存管理方案ARC的引用计数管理一般是针对堆空间...
    Imkata阅读 1,890评论 0 0
  • 原文博客地址: 浅谈Swift的内存管理[https://www.titanjun.top/%E6%B5%85%E...
    TitanCoder阅读 2,102评论 3 11
  • 1.内存管理 跟OC一样,Swift也是采取基于引用计数的ARC内存管理方案(针对堆空间) Swift的ARC中有...
    一抹相思泪成雨阅读 606评论 3 2
  •   跟OC一样,Swift也是采用基于引用计数的ARC内存管理方案(针对堆空间),Swift中的ARC有三种引用:...
    Aliv丶Zz阅读 269评论 0 0
  • 内存管理 ARC是Swift默认的内存管理机制,其针对堆上的对象,由编译器自动生成操作引用计数的指令(retain...
    AAup阅读 653评论 0 1