提示:OC中的字符串有NSString(不可变)和NSMutableString(可变)两类,其中后者是前者的子类。本文通过分析不同种类字符串的内存地址以及对象方法得出copy、mutableCopy的相关特性
mutableCopy篇:
我们知道一个NSString类型的字符串可能会位于内存的常量区,堆区或者棧区(详情请参考博文Mac下NSString(不可变字符串)内存分析
不可变字符串str1、str2、str3位于内存的不同区域,当我们使用mutableCopy方法时,我们会发现返回的地址都是位于堆区的,并且都会在堆区重新分配一个空间。
在这里需要注意的一点是:
当不可变字符串调用mutableCopy方法时,它在堆区分配的新地址,是可以动态的添加和修改的,变成了一个可变字符串
但是我们是不能够通过[str4 appendFormat:]来修改,这是因为我们声明的str4是一个指向NSString类型的,OC的多态允许父类指向子类,但是不允许父类调用子类的特有方法。若调用就会报出错误:
解决办法:
由于copy 、mutableCopy返回的是一个id类型,我们定义一个id 类型的对象访问这个地址,通过它来尝试修改里面的内容,我们便会发现str4虽然不能调用appendFormat,但是指向的空间是可变的
刚开始str4里的内容是“tomtomtomtom”,通过change改变了里面的内容
以上均是不可变字符串调用mutableCopy方法,下面我们声明一个可变字符串,用它来调用mutableCopy方法
我们发现两个字符串的地址都是不相同的,且都是可变的
总结:
1.使用mutableCopy方法,无论是可变对象还是不可变对象,都会在堆区开辟一个新的空间
2.不可变对象调用mutableCopy后,在堆区的空间转为可变的。只是你不能通过一个不可变的父类指针 去调用子类的特有方法
好的idea来自思想的交流和碰撞!