description方法
1.NSLog回顾
众所周知,我们可以用NSLog函数来输出字符串和一些基本数据类
1 int age = 11;
2 NSLog(@"age is %i", age);
* 第2行的%i代表会输出一个整型数据,右边的变量age会代替%i的位置进行输出
* 输出结果:
2013-04-19 21:43:47.674 构造方法[483:303] 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方法返回的字符串代替%@的位置进行输出
* description方法的默认实现是返回这样的格式:<类名: 对象的内存地址>,因此上面代码的输出结果为:
2013-04-19 21:46:49.896 构造方法[492:303] <Student: 0x100109910>
Student是类名,0x100109910是对象的内存地址
* 注意了,%@只能用于输出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方法后,再次执行下面的代码
1 Student *stu = [[Student alloc] initWithAge:10];
2
3 NSLog(@"%@", stu);
4
5 [stu release];
输出结果为:
2013-04-19 22:09:56.625 构造方法[531:303] age=10
4.description方法的陷阱
千万不要在description方法中同时使用%@和self,下面的写法是错误的:
1 - (NSString *)description {
2 return [NSString stringWithFormat:@"%@", self];
3 }
第2行同时使用了%@和self,代表要调用self的description方法,因此最终会导致程序陷入死循环,循环调用description方法
最新文章
- .Net程序在linux mono环境和WindowsServer上执行测试对比
- C#Light V0.08A 执行字符串中的C#
- LLBL Gen Template Studio 2.x
- Android学习笔记(十一)——ListView的使用(下)
- [题解+总结]NOI2015
- 如何做一份能忽悠投资人的PPT
- TCMalloc优化MySQL、Nginx内存管理
- TopCoder SRM 583 TurnOnLamps
- Spark读取HDFS文件,文件格式为GB2312,转换为UTF-8
- vs2010 dll生成,使用问题[good]
- smbpasswd命令常用选项
- cf B. Fixed Points
- 轻松实现语音识别的完整代码在android开发中
- Web数据库的UI框架 Evolutility
- JavaScript中的各种奇葩问题
- stl1
- php错误 分析
- Linux Kernel API
- FreeSWITCH视频会议命令
- 【题解】 [HNOI2002]营业额统计 (Splay)