在封装的类方法内部,也就是+ (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