【转】 NSArray copy 问题

转载▼http://blog.sina.com.cn/s/blog_6b1e4a060102uz0i.html

标签:

nsarray

copy

__nsarrayi

removeobjectatindex

指针指向

分类: 学习笔记

好久没写博客了,今天看到同事的代码中用到了 copy 这个 方法,之前也有了解过,但是不是很深入,概念都比较模糊,虽然已经搞了一年的 iOS 开发,但是 还是 不太了解 真是惭愧,于是乎自己就写了点儿东西来测试,我知道iOS中都是指针 也就是说 如果 有一个 array ,然后申明一个 array1 = [array copy];那么array1和array是指向同一片内存的,所以 当你改变array1 的内容,那么array 也就自然跟着变化了,于是乎便有了以下代码和出现的问题:

NSMutableArray *array = [NSMutableArray
arrayWithObjects:@"111",@"222",@"333",nil];

NSMutableArray *array1 = [array copy];

NSMutableArray *array2 = array1;

NSLog(@"aray:%@,array1:%@,array2:%@",array,array1,array2);

[aray1 removeObjectAtIndex:1];

NSLog(@"aray:%@,array1:%@,array2:%@",array,array1,array2);

按照我们的思路,那么第一次打印出应该全都是 111,222,333,没错,对的

那么第二次打印出什么呢?同样 我们也想着应该是 array 111,222,333, 而 array1 和 array2
打印应该是 111,333,对吗?答案是 错的,为什么呢,因为程序运行到 [aray1
removeObjectAtIndex:1];就报错了,那么报什么错呢,为什么会报错呢?

-[__NSArrayI removeObjectAtIndex:]:
unrecognized selector sent to instance
 这个就是错误,

按照我们的经验,这种错误大概也就array没有这个方法 或者 不能响应这个
方法,怎么可能,明明是 NSMutableArray类型的
怎么可能没有或者不能响应removeObjectAtIdex方法呢,

后来我想了好久,可能是 copy 的问题,于是我把 NSMutableArray
*array1 = [array copy]; 换成 NSMutableArray *array1 = [NSMutableArray
arrayWithArray:array];

这样就不会报错了,问题解决了,

后来我想,虽然问题解决了,但是 这个问题究竟是出在什么地方,为什么会这样呢,想了好久
我大概在猜测,可能是 虽然 array1 我们申明了 NSMutableArray 但是 有可能 copy 后 就成了
NSArray了 之前我有遇到过类似的问题,于是 我就上网查资料 仔细看看 copy
究竟是怎么一回事儿,后来终于明白了,copy是浅拷贝,虽然申明的是NSMutableArray 但是 经过copy
之后的数组还是不可变的,如果要让他可变那么把 [array copy];改成[array
mutableCopy];就可以了,果然我一改 问题立刻就解决了,结果和我们预期一样,

通过这个问题,总结如下:copy 是浅拷贝虽然申明为
NSMutable的变量,结果还是不可变的,如果要让copy之后的变量可变,那么用 mutableCopy 。

虽然开发了一年iOS 但是 基础的东西都还不是太明白,真是 惭愧,还有,如果用
NSString来验证指针指向的问题,似乎不行,因为 NSString *string = @"123";这个方法和 NSString
*string = [[NSString alloc]
initWithString:@"123"];似乎是等价的(这个是我自己猜测的,我之前用过string来验证,谁让string这么简单方便呢,大
家开始都会很自然的想到用string,我也不例外啦),每次都会new出一片内存,这样就达不到我们想要的效果了,所以如果要用
NSString 来验证的话,string初始化最好用 [[NSString alloc]
initWithString:@"123"];这样应该可以。

时间: 2024-12-16 08:29:31

【转】 NSArray copy 问题的相关文章

玩转深拷贝/浅拷贝

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000 } span.s1 { } ======================================== p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000 } span.s

[bugfix]copy属性参数将NSMutableArray变为NSArray类型

问题:NSMutableArray 声明为 copy 属性参数后即使接受NSMutableArray变量依然为NSArray变量 测试: 属性申明为: 1 @property (nonatomic, copy) NSMutableArray *data; 当 1 self.data = [[NSMutableArray alloc] init]; 或者接受一个NSMutableArray变量时候 1234       if (![self.data isKindOfClass: [NSMutab

关于NSArray使用时用strong修饰还是copy修饰问题测试

大家都知道,使用NSMutableArray时是用strong修饰,例如: [objc] view plain copy @property (nonatomic,strong) NSMutableArray * mutableArray; 但是,NSArray呢?我看大多数人都直接使用strong,而且网上还有很多人说除了NSString用copy,其他对象类型都用strong. 那么,问题来了:当用strong修饰NSArray的时候,如果遇到用可变数组给它赋值怎么办?会导致意料之外的bug

iOS之NSArray类簇简介-(copy、mutableCopy导致程序crash)

1.前言 开发时常常用数组对数据进行处理,对NSMutableArray进行操作时经常导致程序崩溃,特研究一下NSArray的类簇!涉及__NSPlaceholderArray.__NSArray0.__NSSingleObjectArrayI.__NSArrayI.__NSArrayM相关类. 2.分析NSArray 2.1.创建不可变出租 NSArray *placeholder = [NSArray alloc]; NSArray *arr1 = [placeholder init]; N

继承NSString,NSArray 怎么写

今天在进行一个字符串测试的时候,自定义了一个继承自NSString的类,但是出现了一些问题,查阅官方文档后得到了下面这些结论 在Objective-C中,对于NSString.NSArray等一些系统的基础类,苹果公司不推荐继承创建新类的,要想给它们扩展功能只能给它们添加新的categroy(类目). 但是直接继承的话,也是可行的,只是会出现各种问题 以NSString为例 首先,创建一个NSString的子类 BFString,不添加任何方法和属性 直接创建一个BFString的实例对象,是没

assign,copy,strong,weak,nonatomic的具体理解

例子: NSString *houseOfMM = [[NSString alloc] initWithString:'MM的三室两厅']; 上面一段代码会执行以下两个动作:  1 在堆上分配一段内存用来存储@' MM的三室两厅 ' ,比如:内存地址为 0X1111  内容为 ' MM的三室两厅' ,  2 在栈上分配一段内存用来存储 houseForWife ,比如:地址为 0XAAAA  内容自然为 0X1111 下面分别看下(assign,retain,copy):  1.assign的情

assign, retain, weak, strong, copy,unsafe_unretain

readonly, readwrite:是控制属性的访问权限,readonly只生成getter方法,其他类是无法修改其值的.readwrite是会同时生成getter和setter方法,其他类可以修改其值. assign, retain, weak, strong, copy,unsafe_unretained:在non-ARC中,assign和retain是一组,assign的对象属性引用计数不变,而retain会被+1.对应的在ARC中,weak和strong是一组,weak的对象属性引用

copy, retain, assign , readonly , readwrite,strong,weak,nonatomic整理

copy:建立一个索引计数为1的对象,然后释放旧对象 对NSString对NSString 它指出,在赋值时使用传入值的一份拷贝.拷贝工作由copy方法执行,此属性只对那些实行了NSCopying协议的对象类型有效.更深入的讨论,请参考“复制”部分. retain:释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1对其他NSObject和其子类对参数进行release旧值,再retain新值指定retain会在赋值时唤醒传入值的retain消息.此属性只能用于Objective

NSArray利用Cocoa框架进行汉字排序

NSArray利用Cocoa框架进行汉字排序 在NSString有一个函数localizedCompare:,它的功能是通过自身与给定字符串的比較,返回一个本地化的比較结果.也就是说这个函数是支持汉字比較的. Student.h @interface Student : NSObject @property(nonatomic,copy)NSString *stuName; @property(nonatomic,assign)CGFloat stuScore; @property(nonato