引用计数和字符串

 

int main(int argc, char *argv[]){ objective-c

NSAutoreleasePool *pool=[[NSAutoreleasePool alloc]init]; spa

    

    NSString *myStr1=@"Constant string"; 设计

    NSString *myStr2=[NSString stringWithString:@"string2"]; 对象

    NSMutableString *myStr3=[NSString stringWithString:@"string3"]; 内存

    

    NSMutableArray *myArr=[NSMutableArray array]; 字符串

    

    NSLog(@"Retain count:myStr1:%lx, myStr2:%lx, myStr3:%lx",(unsigned long)[myStr1 retainCount],(unsigned long)[myStr2 retainCount],(unsigned long)[myStr3 retainCount]); string

    

    [myArr addObject:myStr1]; it

    [myArr addObject:myStr1]; table

    [myArr addObject:myStr3]; 程序设计

    

    NSLog(@"Retain count:myStr1:%lx, myStr2:%lx, myStr3:%lx",(unsigned long)[myStr1 retainCount],(unsigned long)[myStr2 retainCount],(unsigned long)[myStr3 retainCount]);

    

    [myArr addObject:myStr1];

    [myArr addObject:myStr1];

    [myArr addObject:myStr3];

    

    NSLog(@"Retain count:myStr1:%lx, myStr2:%lx, myStr3:%lx",(unsigned long)[myStr1 retainCount],(unsigned long)[myStr2 retainCount],(unsigned long)[myStr3 retainCount]);

    

    [myStr1 retain];

    [myStr2 retain];

    [myStr3 retain];

    

    NSLog(@"Retain count:myStr1:%lx, myStr2:%lx, myStr3:%lx",(unsigned long)[myStr1 retainCount],(unsigned long)[myStr2 retainCount],(unsigned long)[myStr3 retainCount]);

    

[pool drain];

}

输出结果:

Retain count: myStr1:ffffffff, myStr2:ffffffff, myStr3:1

Retain count: myStr1:ffffffff, myStr2:ffffffff, myStr3:2

Retain count: myStr1:ffffffff, myStr2:ffffffff, myStr3:3

NSString对象myStr1赋值为NSConstantString @Constant string”。内存中常量字符串的空间分配与其余对象不一样,它们没有引用计数机制,由于永远不能释放这些对象,这就是为何向mystr1发送消息retainCount,而它返回0xffffffff的缘由。而变量myStr3被设置为常量字符串的副本(NSMutableString *myStr3=[NSString stringWithString:@"string3"];)。制做字符串副本的缘由是向NSMutableString类发送了stringWithString消息,代表该字符串的内容可能在程序执行期间发生变化。因为常量字符串的内容是不能改变的,因此系统不能将变量myStr3设为指向常量字符串@"string3",而myStr2能够。

 

整理摘自《objective-c 2.0程序设计》

相关文章
相关标签/搜索