您的位置:首页 > 运维架构

OC的copy与mutableCopy剖析(mutableCopy篇)

2015-05-10 11:27 197 查看
提示: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来自思想的交流和碰撞!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: