标签:des style blog http color ar 使用 for sp
《Objective-C高级编程》 人民邮电出版社 是一本写的很棒的书,日本作者对于细节抠的很仔细,深入浅出,推荐学习Objective-C的同学们购买。
#1 关于retainCount 变量在内存中是如何存放的?
在GNUStep(一种cocoa框架的互换框架)中retainCount和对象放置在一起,在对象地址之前。所以有如下获取GNUstep中retainCount的方式:
-(NSUInteger) retainCount { return NSExtraRefCount(self) + 1; } inline NSUInteger NSExtraRefCount(id anObject) { return ((struct obj_layout *) anObject )[-1].retained; }
不过苹果的实现是管理了一张hashTable,在通过hash(obj),在相应的位置加入该对象的引用技术retainCount和对象内存块的地址。
虽然GNUstep的实现方式可能会更加直观一些,不过苹果这么做也是有相应的好处的:
#2 autorelease & NSRunloop ?
NSAutoreleasePool这个类对于pool对象使用了管理者模式,即会管理许多个pool 并且记录当前正在使用的pool,如果在别的地方使用了 [[[class alloc] init] autorelease],那么该对象就会被加入这个正在使用的pool中。
#3 如何提高Objective-C方法的调用速度?
“IMP Caching”方法
提高频繁调用的autorelease方法的速度:例
id autorelease_class = [NSAutoreleasePool class]; SEL autorelease_sel = @selector(addObject:); IMP autorelease_imp = [autorelease_class methodForSelector:autorelease_sel]; - (id) autorelease { (* autorelease_imp)(autorelease_class,autorelease_sel,self); } - (id)autorelease { [NSAutoreleasePool addObject:self]; }
在框架初始化的时候对,这几个方法进行了缓存。第一种autorelease的调用速度是后者的2倍。因为Oc-runtime 中有对象之间发送消息的开销。
#4 SEL 和 IMP的区别?
typedef struct objc_selector *SEL;
typedef id (*IMP)(id, SEL, ...);
IMP 是一个函数指针,这个被指向的函数包含一个接收消息的对象id(self 指针), 调用方法的选标 SEL (方法名),以及不定个数的方法参数,并返回一个id。也就是说 IMP 是消息最终调用的执行代码,是方法真正的实现代码 。我们可以像在C语言里面一样使用这个函数指针。
#5 _weak 赋值给 _strong 时的情况?
#6 _unsafe_unretained 为何物?
实际上就是不会自动置nil的指针 (_weak),所以可能会出现野指针。
#7 @autorelease 块
在块结束的时候调用,[pool drain] ;
#8 C++智能指针的问题 std:: shared_ptr & std:: weak_ptr & std:: auto_ptr
引入了引用计数器的概念。
#9 NSZone是什么?
在碰到allocWithZone, copyWithZone总会有个疑问,这个NSZone到底是个什么东西?简单来说,可以想象成一个内存池,alloc或是dealloc这些操作,都是在这个内存池中操作的。cocoa总是会配置一个默认的NSZone,任何默认的内存操作都是在这个“zone”上操作的。默认的NSZone的缺陷在于,它是全局范围的,时间一长,必然会导致内存的碎片化,如果你需要大量的alloc一些object,那么性能就会受到一些影响。所有cocoa提供方法,你可以自己生成一个NSZone,并将alloc, copy全部限制在这个“zone”之内。
#10 在删除动态数组的时候需要注意的?
需要讲所有元素置为nil,不然会发生内存泄漏。即使使用memset等函数将内存填充为0也不会释放所赋值的对象。对于编译器,必须明确得使用赋值给附有_strong 修饰的变量的源代码。
for( NSUInteger i = 0; i < entries ;++i ) array[i] = nil ; free(array);
#11 _weak表
在ARC条件下,当_weak指向的对象被释放了,那么_weak会自动被置为nil,那么runtime中是如何做到这一点的呢?
在内存中维护一张weak表。
/* oc代码 */ { id __weak obj1 = obj; } /* 编译器模拟代码 */ id obj1; objc_initWeak(&obj1,obj); objc_destroyWeak(&obj1);
如上述代码,key 为对象的地址 obj ,values为 _weak的地址&obj1 。 一个对象地址可以对应很多个_weak变量地址,当一个对象被析构,那么他在weak表中所指向的_weak变量就会被置为nil。然后在weak表中删除该记录。
由于使用_weak变量会造成以上的系统开销,所以仅在需要避免循环引用的时候使用__weak修饰符。
#12 在ARC条件下如何获取retainCount ?
使用: _objc_rootRetainCount(obj);
标签:des style blog http color ar 使用 for sp
原文地址:http://www.cnblogs.com/xdxer/p/4069650.html