用类方法------>快速创建一个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:120]; NSLog(@"%ld",[p1 retainCount]); } return 0; }
// 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