用类方法------>快速创建一个autorelease的对象,在封装的类方法内部

时间:2023-03-09 09:25:38
用类方法------>快速创建一个autorelease的对象,在封装的类方法内部

在封装的类方法内部,也就是+ (id)personWithName:(NSString *)name andAge:(int)age内部:

创建了一个person对象,并且创建了一个person*类型的指针p1指向这个对象。

此时不用考虑指针p1对新创建对象retaincount的影响,因为此时(创建person对象并赋值给p之后)对象的计数器为1,类方法结束后指针p1是局部变量被回收,且将存储的地址传递给mian函数中的p2,所以现在p2指向新创建的person对象,此对象的计数器还是1。

从结果来看就是从 p1引用新对象 变成 P2引用新对象,计数器不变。

 // main.m

#import <Foundation/Foundation.h>
#import "Person.h" int main(int argc, const char * argv[]) {
@autoreleasepool
{
Person *p1 = [Person personWithName:@"东方不败" andAge:];
NSLog(@"%ld",[p1 retainCount]);
}
return ;
}
// Person.h
#import <Foundation/Foundation.h> @interface Person : NSObject
@property (nonatomic,assign) int age;
@property (nonatomic,retain) NSString *name;
- (void)setName:(NSString *)name andAge:(int)age;
+ (id)personWithName:(NSString *)name andAge:(int)age;
@end
// Person.m
#import "Person.h" @implementation Person
+ (id)personWithName:(NSString *)name andAge:(int)age
{ Person *p = [[[self alloc] init] autorelease];
p.name = name;
p.age = age;
NSLog(@"%ld",[p retainCount]);
return p;
}
- (void)setName:(NSString *)name andAge:(int)age
{
self.name = name;
self.age = age;
}
- (void)dealloc
{
[_name release];
[super dealloc];
}
@end

相关文章