1、copy:
1??NSString、NSArray、NSDictionary 等等经常使用copy关键字,是因为他们有对应的可变类型:NSMutableString、NSMutableArray、NSMutableDictionary;
2??block 也经常使用 copy 关键字;建立一个索引计数为1的对象,然后释放旧对象。
2、weak:必须用于OC对象(一般防止循环引用,比如delegate属性、IBOUlet控件(当然也可以用Strong)).weak修饰的对象在释放之后,指针地址会被置为nil。所以现在一般弱引用就是用weak。?
3、assign:用于非OC对象,一般用于基本数据类型(例如 CGFloat 或 NSlnteger 、BOOL等),简单赋值,不更改索引计数.assign其实也可以用来修饰对象,那么我们为什么不用它呢?因为被assign修饰的对象在释放之后,指针的地址还是存在的,也就是说指针并没有被置为nil。如果在后续的内存分配中,刚好分到了这块地址,程序就会崩溃掉。?
4、strong:修饰OC对象。
5、retain:释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1 ,对其他NSObject和其子类
6、weak和strong的区别:weak和strong不同的是 当一个对象不再有strong类型的指针指向它的时候 它会被释放 ,即使还有weak型指针指向它。一旦最后一个strong型指针离去 ,这个对象将被释放,所有剩余的weak型指针都将被清除。
何时使用的问题,如果一个对象在某段时间中反复加载,而你又不希望每次加载都要重新alloc 的话,那就strong,strong 保证对此对象保持一个强引用,对于这个对象,只要有1个strong引用的话,那它就不会释放,当然多个strong同时作用于它也不会释放。
如果一个对象在某段时间只会加载一次,并且加载之后确定不再使用了,那就可以使用weak,这样当其他原因导致引用计数减1(比如 removefromsuperview)的时候,此对象就自动释放了。无需再在delloc 里面再release一次,但你要保证释放之后确实不再使用此对象,否则将导致错误
其实strong和retina的作用有些像,只不过strong 和weak是在arc里面引入的,他俩算是一对儿, 对应关系有点类似 retiam 和assign?
7、copy与retain的区别:
copy其实是建立了一个相同的对象,而retain不是;
copy是内容拷贝,retain是指针拷贝;
copy是内容的拷贝 ,对于像NSString,的确是这样,如果拷贝的是NSArray这时只是copy了指向array中相对应元素的指针.这便是所谓的"浅复制"。
8、__block和__weak修饰符的区别:
__block不管是ARC还是MRC模式下都可以使用,可以修饰对象,还可以修饰基本数据类型。
__weak只能在ARC模式下使用,也只能修饰对象(NSString),不能修饰基本数据类型(int)。
__block对象可以在block中被重新赋值,__weak不可以。
首先__block是用来修饰一个变量,这个变量就可以在block中被修改(参考block实现原理)?
__block:使用__block修饰的变量在block代码快中会被retain(ARC下,MRC下不会retain)?
__weak:使用__weak修饰的变量不会在block代码块中被retain?
同时,在ARC下,要避免block出现循环引用 __weak typedof(self)weakSelf = self;
typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。
它返回值是一个字符串,该字符串说明运算数的类型。
个人理解为:可以根据typeof()括号里面的变量,自动识别变量类型并返回该类型。
下面为代码测试:
NSString *str; __strong typeof(str) a = @"2"; BOOL isClass = [a isKindOfClass:[NSString class]]; if (isClass == YES) { ???
?NSLog(@"yes");?
}
常见运用于Block?
首先在下面的block代码中需要用到self,但是我们都知道block会对里面的代码变量进行strong reference,导致内存泄漏。?
所以在block内如果有self的话,一般都会在block外面加一句_block typeof(self)tempSelf = self;