OC中NSString对象retainCount之谜探索

本文深入探讨了Objective-C中字符串常量、使用stringWithFormat创建的NSString对象以及stringWithString方法生成的对象在内存管理上的区别。通过详细分析,揭示了这些对象如何在内存中被分配、引用计数的增减以及最终回收的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 字符串常量,类似于C语言形式,静态区存储
  
  1. NSString *s = @"test";
  2.   NSLog(@"s:%lx",[s retainCount]);//输出值为0xffffffffffffffff(UINT_MAX)
  3.   NSLog(@"s:%ld",[s retainCount]);//输出值-1,由于0xffffffffffffffff补码表示的值为-1
复制代码

  因为"test"为字符串常量,系统不会采用计数方式回收,所以不会对其作引用计数,即使我们对s如何retain或release,其值保持不变,对象也保持不变。

  2. stringWithFormat
  
  1. NSString *s = [NSString stringWithFormat:@"%s", "test"];
  2.   NSLog(@"s:%d",[s retainCount]); //输出值为1
复制代码

  使用stringWithFormat创建的NSString为变量,系统会进行引用计数,和普通对象一样。

  3. stringWithString

  stringWithString这个方法比较特别:分两种情况,它的retainCount取决于它后面跟的string对象
  
  1. 情况1:NSString *s1 = [NSString stringWithString:@"test"];
  2.   NSLog(@"s1:%d",[s1 retainCount]); // 2147483647
  3.   情况2:NSString *s2 = [NSString stringWithString:[NSString stringWithFormat:@"test,%d",1]];
  4.   NSLog(@"s2:%d",[s2 retainCount]); // 2
复制代码

  可以看到情况1为"常量"对象,其retainCount方法的实现返回的是maxIntValue。

  情况2输出值为2,也证明了前面说的,这个方法生成的只是一个对另一个对象的引用。 一个对象实例,一次stringWithFormat (+1)和stringWithString(+1),它的retainCount为2,同时都被当前的AutoreleasePool管理。

  4.NSMutableString
  
  1. NSMutableString* myStr3 = [NSMutableString stringWithString:@"string 3"];
复制代码

  输出1,有引用计数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值