将实例ID打印到NSLog?

时间:2009-09-09 11:49:16

标签: objective-c memory nslog dealloc

在类的dealloc方法中,如何为要解除分配的实例打印ID(或其他一些唯一标识符)?

- (void)dealloc {
    NSLog(@"_deallocing: ??");
    [super dealloc];
}

这可能吗?我只是想在控制台中获得更多反馈,以帮助学习。

非常感谢-gary -

2 个答案:

答案 0 :(得分:54)

如果您特别需要对象的内存地址(如果您的类中没有实现,我认为可以将其视为“标识符”),您可以使用:

NSLog(@"deallocing %p", self);

如果您有一个特定类的多个实例并且正在尝试确定哪个实例在dealloc'd时会有用,这可能会非常有用。

答案 1 :(得分:7)

试试这个:

- (void)dealloc {
    NSLog(@"_deallocing: %@", self);
    [super dealloc];
}

这将向控制台输出有关该对象的更多信息。根据类,您将获得内存地址和类名称或更详细的内容。如果您想在自己的类中提供更详细的内容,请覆盖此方法并返回您想要的任何内容:

-(NSString *)description {
    return @"Something useful about this object";
}