NSLog在重写描述方法中的对象的内存地址

时间:2011-09-26 12:36:09

标签: objective-c nslog

我正在覆盖对象的描述方法。我需要知道如何打印对象的内存地址以替换下面代码中的 {???}

-(NSString *) description {
    return [NSString stringWithFormat:@"<SomeClass: %@>\nparmeterOne: %@\nparameterTwo: %@",
            {???}, self.parameterOne, self.paramterTwo];
}

我希望它在控制台中打印,如下所示:

<SomeClass: 0x4c05600> parameterOne: 12 parameterTwo: sausages

2 个答案:

答案 0 :(得分:208)

打印地址使用%p格式说明符和自指针:

-(NSString *) description {
    return [NSString stringWithFormat:@"<SomeClass: %p>\nparmeterOne: %@\nparameterTwo: %@",
            self, self.parameterOne, self.paramterTwo];
}

答案 1 :(得分:6)

最简单的方法是使用超级描述

- (NSString *)description
{
    return [NSString stringWithFormat:@"%@ Area: %@, %@", [super description], self.identifier, self.name];
}

因此,在这个模型对象是NSObject的子类的情况下,你可以躲避额外的工作并记住%p

手动使用NSStringWithClass()和%p

- (NSString *)description
{
    return [NSString stringWithFormat:@"<%@: %p> Area: %@, %@", NSStringFromClass([self class]), self, self.identifier, self.name];
}

因此,对于一个对象模型,你有一个从这个类派生的具体实现者,你将显示正确的类名。