刚发现了一个神奇的问题,创建了一个新的NSNumber对象,然后打印引用计数。发现得到的值大多数时候与预期的值并不相同。
如通过[NSNumbernumberWithInt:1]得到的对象在我的电脑上测试引用计数居然为32。想破头都没有弄明白是什么原因。
测试一下再调用一次[NSNumbernumberWithInt:1]
NSNumber* a = [[NSNumber alloc] initWithInt:1];
NSLog(@"a:%d",[a retainCount]);
NSNumber* b = [NSNumber numberWithInt:1];
NSLog(@"a:%d",[a retainCount]);
NSLog(@"b:%d",[b retainCount]);
结果:
2011-11-04 17:30:57.847 10030[5213:207] a:32
2011-11-04 17:30:57.848 10030[5213:207] a:33
2011-11-04 17:30:57.849 10030[5213:207] b:33
原来内部实现的时侯,从变量堆栈中读取了相同的值。