#pragma mark指令
本小节知识点:
- 【了解】#pragma mark指令的使用
1.#pragma mark指令的使用
-
功能:简单来说就是对代码的分组,方便代码查找和导航用的 它们告诉Xcode编译器,要在编辑器窗格顶部的方法和函数弹出菜单中将代码分隔开。一些类(尤其是一些控制器类)可能很长,方法和函数弹出菜单可以便于代码导航。此时加入#pragma 指令(#pragma是一个编译指令)对代码进行逻辑组织很有效果。
-
一个类里我们总会有一些方法的功能与性质是相差不多的,你可能会有把方法们分组的想法。Xcode已经有了类似的支持,它就是 #pragma mark。
-
分组: #pragma mark 分组(标识)名称
-
分隔线: #pragma mark -
-
分割线加分组: #pragma mark - 分组(标识)名称
-
description方法
本小节知识点:
- 【掌握】description基本概念
- 【掌握】description重写的方法
- 【了解】description陷阱
1.description基本概念
-
NSLog(@"%@", objectA);这会自动调用objectA的descriptong方法来输出ObjectA的描述信息.
-
descriptong方法默认返回对象的描述信息(默认实现是返回类名和对象的内存地址)
-
description方法是基类NSObject 所带的方法,因为其默认实现是返回类名和对象的内存地址, 这样的话,使用NSLog输出OC对象,意义就不是很大,因为我们并不关心对象的内存地址,比较关心的是对象内部的一些成变量的值。因此,会经常重写description方法,覆盖description方法 的默认实现
2.description重写的方法
- 对象方法
/**对象方法:当使用NSLog输出该类的实例对象的时候调用*/
-(NSString *) description
{
return [NSString stringWithFormat:@"狗腿数:%d,狗眼数%d
",_legNum,_eyeNum];
}
- 类方法
/**类方法:当使用NSLog输出该类的类对象的时候调用*/
+(NSString *) description
{
return @"+开头的description方法";
}
3.description陷阱
- 千万不要在description方法中同时使用%@和self,下面的写法是错误的
- (NSString *)description { return [NSString stringWithFormat:@"%@", self]; }
-
同时使用了%@和self,代表要调用self的description方法,因此最终会导致程序陷入死循环,循 环调用description方法
-
当[NSString stringWithFormat:@“%@”, self]; 使用它时,循坏调用,导致系统会发生运行时错误。
-
当该方法使用NSLog(“%@”,self) 时候, 系统做了相关的优化,循坏调用3次后就会自动退出
OC多文件开发介绍
本小节知识点:
- 【了解】为什么要使用多文件
- 【理解】@interface和@implementation的分工
- 【理解】在OC中如何进行多文件开发?
- 【了解】使用多文件开发好处
1.为什么要使用多文件
-
一个真正的iOS项目中可能会有成百上类,如果这些类都写在一个文件中,那么文件就会很大,想找到自己需要类都变的异常困难,开发效率低下
-
一个iOS项目可能会有多个人开发,如果多个人同时修改一个文件,那么就很可能会产生冲突,比如这个增加一个方法,那个人把这方法删掉了。另外就是当把多个人写功能合并起来的时候,也非常困难,写到一个文件中,无法顺畅的进行团队合作。
2.@interface和@implementation的分工
- @interface就好像暴露在外面的时钟表面
- @implementation就好像隐藏在时钟内部的构造实现
3.在OC中如何进行多文件开发?
- 在工作中,通常把不同的类放到不同的文件中,每个类的声明和实现分开
- 声明写在.h头文件中,
- 实现写在相应的.m文件中去,
- 类名是什么,文件名就是什么。
objc 假设有两个类,分别是Person类和Dog类,则通常有下面五个文件:
(1)Person.h Person类的声明文件
(2)Person.m Person类的实现文件
(3)Dog.h Dog类的声明文件
(4)Dog.m Dog类的实现文件
(5)Main.m 主函数(程序入口)
在主函数以及类的实现文件中要使用#import包含相应的头文件。
- ---
4.使用多文件开发好处
- 显著提高团队协作的效率
- 提高程序的开发速度
- 提高程序的可维护性
- 提高代码的可读性