码迷,mamicode.com
首页 > 其他好文 > 详细

什么情况下才要重写Objective-C中的description方法

时间:2015-07-12 23:05:55      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:

特别注意:

千万不要在description方法中同时使用%@和self,同时使用了%@和self,代表要调用self的description方法,因此最终会导致程序陷入死循环,循环调用description方法

1.NSLog回顾

 

大家都知道,我们可以用NSLog函数来输出字符串和一些基本数据类

 

 1 int age = 11;

 2 NSLog( @" age is %d", age);

 

* 第2行的%d代表会输出一个整型数据,右边的变量age会代替%d的位置进行输出

 

* 输出结果:

 age is 11

 

2.NSLog输出OC对象

 

其实,除了可以输出基本数据类型,NSLog函数还可以输出任何OC对象

 

     1 Student *stu = [[Student alloc] initWithAge:10];

     2 

     3 NSLog(@"%@", stu);

     4 

     5 [stu release];

 

 

* 在第3行用NSLog函数输出stu对象,注意左边的格式符%@,以后想输出OC对象,就得用%@这个格式符

 

* NSLog函数一旦发现用%@输出某个OC对象时,就会调用这个对象的description方法(这个方法返回值是NSString类型,是OC中的字符串类型),并且将description方法返回的字符串代替%@的位置进行输出

 

*上面代码的输出结果为:0x100109910>

 

Student是类名,0x100109910是对象的内存地址

例子:(没有重写OC中的description方法时)description方法的默认实现是返回这样的格式:<类名: 对象的内存地址>

 

 

* 注意了,%@只能用于输出OC对象,不能输出结构体等其他类型

 

* 有Java开发经验的人应该能感受到OC中的description方法就是Java中的toString方法

 

3.重写description方法

 

description方法的默认实现是返回类名和对象的内存地址,这样的话,使用NSLog输出OC对象,意义就不是很大,因为我们并不关心对象的内存地址,比较关心的是对象内部的一些成变量的值。因此,会经常重写description方法,覆盖description方法的默认实现

比如,重写Student的description方法,返回成员变量_age的值

 

     1 - (NSString *)description {

     2 return [NSString stringWithFormat:@"age=%i", _age];

     3 }

 

* 在第2行调用了NSString这个类的静态方法stringWithFormat初始化一个字符串对象,并返回这个字符串

 

* 如果你会使用NSLog的话,那就应该能理解第2行的方法参数是什么意思了

 

* 假如_age是10,那么description方法返回的字符串就是@"age=10"

 

* 可能有人会觉得奇怪,之前创建的Student对象是需要释放的,为什么这里创建的字符串对象不用释放?要想彻底明白这个问题,需要先了解OC的内存管理,这里我们暂不做详细讨论,后面会有章节详细讨论内存管理。你可以先记住一个规则:一般情况下,静态方法返回的对象,都不用手动释放。

 

* 重写完description方法后,再次执行下面的代码

 

            Student *stu = [[Student alloc] initWithAge:10];

     2 

     3 NSLog(@"%@", stu);

     4 

     5 [stu release];

 

1输出结果为:

 age=10

 

4.description方法的陷阱

 

千万不要在description方法中同时使用%@和self,下面的写法是错误的:

 

            - (NSString *)description {

     2 return [NSString stringWithFormat:@"%@", self];

     3 }

 

 

1第2行同时使用了%@和self,代表要调用self的description方法,因此最终会导致程序陷入死循环,循环调用description方法

 

什么情况下才要重写Objective-C中的description方法

标签:

原文地址:http://www.cnblogs.com/ZhiRongqun/p/4641576.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!