assign,copy,retain和weak,strong(借鉴别人并整理的)

assign,copy,retain(转载并整理的)

学习ios有一段时间了,今天打算总结一下assign,copy,retain,以下内容是我看别人写的文章,从中截取的,并简单进行了整理。

 

•   alloc 对象分配后引用计数为1

•   retain 对象的引用计数+1

•   copy copy 一个对象变成新的对象(新内存地址)引用计数为1 原来对象计数不变

•   release 对象引用计数-1 如果为0释放内存

•   autorelease 对象引用计数-1 如果为0不马上释放,最近一个个pool时释放

 

  1. 使用assign: 对基础数据类型 (NSInteger)和C数据类型(int, float, double, char,等)
  2. 使用copy: 对NSString
  3. 使用retain: 对其他NSObject和其子类

 

对应set方法写法:

// assign

-(void)setTestObject :(id)newValue{

testObject= newValue;

}

// retain

-(void)setTestObject :(id)newValue{

if (testObject!= newValue) {

[testObject release];

testObject= [newValue retain];

}

}

// copy

-(void)setTestObject :(id)newValue{

if (testObject != newValue) {

[testObject release];

testObject = [newValue copy];

}

}

 

误释放对象

问题一:view plaincopy to clipboardprint?

1.  value = [array objectAtIndex:n]; //得到一个数组中的对象

2.  [arry removeObjectAtIndex:n]; //卸载那个对象

因为value得到了那个对象,但是由于另外一个拥有者release了该对象,所以其实value现在成了摇摆指针(无效数据)

 

iOS 5 中对属性的设置新增了strong 和weak关键字来修饰属性(iOS 5 之前不支持ARC)

 

strong 用来修饰强引用的属性;

@property (strong) SomeClass * aObject;

对应原来的

@property (retain) SomeClass * aObject; 和@property (copy) SomeClass * aObject;

 

weak 用来修饰弱引用的属性;

@property (weak) SomeClass * aObject;

对应原来的

@property (assign) SomeClass * aObject;

 

strong关键字与retain关似,用了它,引用计数自动+1,用实例更能说明一切

 

@property (nonatomic, strong) NSString *string1;  

@property (nonatomic, strong) NSString *string2; 

 

有这样两个属性,

@synthesize string1;   

@synthesize string2;  

 

 

猜一下下面代码将输出什么结果?

 

self.string1 = @"String 1";   

self.string2 = self.string1;   

self.string1 = nil;  

NSLog(@"String 2 = %@", self.string2); 

 

 

结果是:String 2 = String 1由于string2是strong定义的属性,所以引用计数+1,使得它们所指向的值都是@"String 1", 如果你对retain熟悉的话,这理解并不难。

 

接着我们来看weak关键字:

如果这样声明两个属性:


@property (nonatomic, strong) NSString *string1;  

@property (nonatomic, weak) NSString *string2; 

并定义 

@synthesize string1;   

@synthesize string2;  

 

再来猜一下,下面输出是什么?

 

 self.string1 = @"String 1";   

self.string2 = self.string1;   

self.string1 = nil;  

NSLog(@"String 2 = %@", self.string2); 

结果是:String 2 = null

 

        分析一下,由于self.string1与self.string2指向同一地址,且string2没有retain内存地址,而self.string1=nil释放了内存,所以string1为nil。声明为weak的指针,指针指向的地址一旦被释放,这些指针都将被赋值为nil。这样的好处能有效的防止野指针。在c/c++开发过程中,为何大牛都说指针的空间释放了后,都要将指针赋为NULL. 在这儿用weak关键字帮我们做了这一步。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值