1:-(description)对象方法 使用NSLog和%@输出某个对象时。会调用对象的description 方法,并得到返回值进行输出
2:使用 %@打印输出对象时,默认打印输出<类名 内存地址> ,NSLog 函数一旦发现用%@输出某个OC对象时,就会调用对象的description方法(默认为NSString类型),并将 description方法返回的Oc字符串返回到屏幕上,OC中的description方法类似于Java中的toString方法
3: 直接输出某个对象的地址:
Person *p = [person new];
NSLog(@"%p",p);
输出指针变量的地址
NSLog(@"%p",&p);
直接输出整个对象
NSLog(@"%@",p);默认打印输出<类名 内存地址>,改变默认输出的方式:重写-description方法
#import <Foundation/Foundation.h>
@interface Person:NSObject
//使用@property会自动生成set和get方法
@property(nonatomic ,strong) NSString *name;
@property (nonatomic,assign)int age;
@end
@implementation Person
@end
int main()
{
Person *p =[Person new];
//点语法调用的是set方法还是get方法取决于其是否设值,如果设置则为set方法,反之则为get方法
//点语法 编译器会自动生成代码【p setAge:20】
p.age = 20;
//点语法 编译器会自动生成代码【p setName:@"zhangsan"】
p.name = @"zhangsan";
//%p 直接输出某个对象的地址
NSLog(@"对象Person的地址为:%p",p);
//(%p,&p)输出指向对象的指针的地址
NSLog(@"指针的地址为%p",&p);
//(%@,p)输出所有的OC对象,默认输出的方式为【类名 对象的内存地址】。指针变量P所指向的对象会发送一条description消息,调用description方法,并且将description方法返回的OC字符串输出到屏幕上
NSLog(@"%@",p);
//输出对象名称,不输出具体属性
Class c =[Person class];
NSLog(@"%@",c);
return 0;
}
打印输出的结果为:
为了能够实现打印输出对象的所有属性,可以重写description方法
#import <Foundation/Foundation.h>
@interface Person:NSObject
@property(nonatomic ,strong) NSString *name;
@property (nonatomic,assign)int age;
@end
@implementation Person
//重写description方法
-(NSString *)description
{
return [NSString stringWithFormat:@"姓名:%@ 年龄:%i",_name,_age];
}
@end
int main()
{
Person *p =[Person new];
p.age = 20;
p.name = @"zhangsan";
NSLog(@"对象Person的地址为:%p",p);
NSLog(@"指针的地址为%p",&p);
NSLog(@"%@",p);
Class c =[Person class];
NSLog(@"%@",c);
return 0;
}
运行结果为: