ARC机制之__strong具体解释


__strong  解析:

默认情况下,一个指针都会使用 __strong 属性,表明这是一个强引用。这意味着,仅仅要引用存在,对象就不能被销毁。这是一种所期望的行为:当全部(强)引用都去除时,对象才干被收集和释放。

只是, 有时我们却希望禁用这样的行为:一些集合类不应该添加其元素的引用。由于这会引起对象无法释放。在这样的情况下,我们须要使用弱引用(不用操心,内置的集合类就是这么干的),使用 __weak
keyword。NSHashTable就是一个样例。

当被引用的对象消失时,弱引用会自己主动设置为 nil。Cocoa的 Notification Center
就是这么一个样例,尽管这已经超出纯 Objective-C的语言范畴

自己更深理解:

1.(weak与strong)不同的是:当一个对象不再有strong类型的指针指向它的时候,它就会被释放,即使改对象还有_weak类型的指针指向它;

在OC中strong就相当于retain属性,而weak相当于assign。仅仅有一种情况你须要使用weak(默认是strong),就是为了避免retain cycles(就是父类中含有子类{父类retain了子类}。子类中又调用了父类{子类又retain了父类},这样都无法release)

2.一旦最后一个指向该对象的strong类型的指针离开,这个对象将被释放,假设这个时候还有weak指针指向该对象,则会清除掉全部剩余的weak指针

以下是笔者看书时遇到的疑问

(1) : __strong在ARC关闭时是否可用

(2): __strong修饰的变量,直接赋值时,赋值的变量的retain是否会自增(被赋值的变量retain是否会自减)

(3): __strong修饰的变量在超出其作用域时retain是否会自减

解答例如以下:

(1): 能

(2): 比如:

;

id __strong obj1 =nil;

id
__strong obj = [[NSObjectalloc]
init];

obj1 = obj;//obj1
持有obj 赋值对象的强引用
会导致obj retain自增

NSLog(@"Retain count is %ld",CFGetRetainCount((__bridgeCFTypeRef)obj));

NSLog(@"obj = %ld",CFGetRetainCount((__bridgeCFTypeRef)obj));

打印例如以下:

2015-07-22 17:23:22.169字典[724:25567] Retain count is 2

2015-07-22 17:23:22.171字典[724:25567] obj = 2

说明:(1) :当一个对象获得还有一个对象的强引用时,retain++;

(2): 被赋值的变量retain是会自减

(3):

;

id
__strong obj1 =nil;

if(count){

id
__strong obj = [[NSObjectalloc]
init];

obj1 = obj;//obj1
持有obj 赋值对象的强引用
会导致obj retain自增

NSLog(@"Retain count is %ld",CFGetRetainCount((__bridgeCFTypeRef)obj));

}

NSLog(@"Retain count is %ld",CFGetRetainCount((__bridgeCFTypeRef)obj1));

__strong修饰的变量在超出其作用域时retain是会自减

ARC机制之__strong具体解释的更多相关文章

  1. 黑马程序员——ARC机制总结和用ARC建立模型

    ARC 全称:Automatic Reference Counting 使用ARC 只需要在建立一个新的项目的时候把 下面的√打上 Xcode5以后都会默认建议开发者使用ARC机制 新的项目中如果有部 ...

  2. [转]iOS ARC机制 weak strong

    写在开头 虽然距离WWDC2011和iOS 5已经快一年时间,但是很多开发者并没有利用新方法来提高自己的水平,这点在ARC的使用上非常明显(特别是国内,基本很少见到同行转向ARC).我曾经询问过一些同 ...

  3. ARC机制集合内存管理

    // //  main.m //  13-ARC机制集合内存管理 // //  Created by apple on 14-3-21. //  Copyright (c) 2014年 apple. ...

  4. ARC机制下组合关系

    // //  Person.h //  01-autorelease基本概念 // //  Created by apple on 14-3-18. //  Copyright (c) 2014年 a ...

  5. ARC机制

    ARC概念及原理 1.了解指针分类 (1)强指针:默认的情况下,所有的指针都是强指针,关键字strong (2)弱指针:_ _weak关键字修饰的指针 声明一个弱指针如下: _ _weak Perso ...

  6. iOS开发ARC机制下的内存管理技术要点

    转载一篇: iOS开发ARC内存管理技术要点.ARC内存管理原则总结.iOS ARC内存管理总结 ARC内存管理机制 (一)ARC的判断准则: 只要没有任何一个强指针指向该对象,该对象就会被释放. ( ...

  7. OC内存管理、非ARC机制、MRR机制

    在Xcode里面,默认为ARC(auto reference counting),也就是自动内存管理机制,在这里我们要了解的是内存管理,肯定是不能让系统帮我们管理内存,我们需要将ARC关闭,首先在左边 ...

  8. 【iOS开发-34】自己主动释放池@autoreleasepool的使用注意事项以及ARC机制——面试必考内容

    自己主动释放池@autorelease面试频率可能会吧release还要高. (1)在自己主动释放池@autoreleasepool{}中alloc一个对象后(如p1).仍然须要用[p1 autore ...

  9. ARC中__weak;__strong;__unsafe_unretained;修饰词

    测试代码: // Human.h代码 @interface Human : NSObject @property (nonatomic, weak) Cat *pinkCat; @property ( ...

随机推荐

  1. 学习笔记7——wp版本更新需要注意的问题

    平时开发时应该避免修改wp的核心代码, 因为在升级wp版本时,核心代码都会被覆盖, wp升级时只有wp-content文件夹不会被覆盖.

  2. NYOJ 722 数独

    数独 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 数独是一种运用纸.笔进行演算的逻辑游戏.玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一 ...

  3. matalb sum函数和sum变量的用法

    在对矩阵或者向量求和要用到sum函数的时候代码里面千万不要出现将sum作为变量名

  4. poj 3617Best Cow Line

    Description FJ is about to take his N (1 ≤ N ≤ 2,000) cows to the annual"Farmer of the Year&quo ...

  5. Mahout0.9安装与配置(完全分布式模式下运行)

    安装Mahout之前,一定要把hadoop装好,hadoop的安装方法可以参考我的前一篇随笔,我安装的是hadoop2.7.0,具体方法在此不做介绍. 1.首先下载相应版本的Mahout: axel ...

  6. BZOJ 2179 FFT快速傅立叶 ——FFT

    [题目分析] 快速傅里叶变换用于高精度乘法. 其实本质就是循环卷积的计算,也就是多项式的乘法. 两次蝴蝶变换. 二进制取反化递归为迭代. 单位根的巧妙取值,是的复杂度成为了nlogn 范德蒙矩阵计算逆 ...

  7. BZOJ1926 [Sdoi2010]粟粟的书架 【主席树 + 二分 + 前缀和】

    题目 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Co rmen 的文章.粟粟家中有一个 R行C 列的巨型书架,书架的每一个位置都 ...

  8. 【kmp+求所有公共前后缀长度】poj 2752 Seek the Name, Seek the Fame

    http://poj.org/problem?id=2752 [题意] 给定一个字符串,求这个字符串的所有公共前后缀的长度,按从小到达输出 [思路] 利用kmp的next数组,最后加上这个字符串本身 ...

  9. django 和 mongdb 写一个简陋的网址,以及用django内置的分页功能

    https://github.com/factsbenchmarks/simple_websit_about_58 一 设置 数据库的设置 在settings文件中加入这样一段代码: from mon ...

  10. uva 11997 优先队列

    K Smallest Sums You're given k arrays, each array has k integers. There are kk ways to pick exactly ...