晚点的等待

博客园 首页 新随笔 联系 订阅 管理

#pragma mark指令

本小节知识点:

  1. 【了解】#pragma mark指令的使用

1.#pragma mark指令的使用

  • 功能:简单来说就是对代码的分组,方便代码查找和导航用的 它们告诉Xcode编译器,要在编辑器窗格顶部的方法和函数弹出菜单中将代码分隔开。一些类(尤其是一些控制器类)可能很长,方法和函数弹出菜单可以便于代码导航。此时加入#pragma 指令(#pragma是一个编译指令)对代码进行逻辑组织很有效果。

  • 一个类里我们总会有一些方法的功能与性质是相差不多的,你可能会有把方法们分组的想法。Xcode已经有了类似的支持,它就是 #pragma mark。

    • 分组: #pragma mark 分组(标识)名称 

    • 分隔线: #pragma mark - 

    • 分割线加分组: #pragma mark - 分组(标识)名称 

 

description方法

本小节知识点:

  1. 【掌握】description基本概念
  2. 【掌握】description重写的方法
  3. 【了解】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\n",_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多文件开发介绍

本小节知识点:

  1. 【了解】为什么要使用多文件
  2. 【理解】@interface和@implementation的分工
  3. 【理解】在OC中如何进行多文件开发?
  4. 【了解】使用多文件开发好处

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.使用多文件开发好处

  • 显著提高团队协作的效率
  • 提高程序的开发速度
  • 提高程序的可维护性
  • 提高代码的可读性

posted on 2015-12-02 23:32  晚点的等待  阅读(143)  评论(0编辑  收藏  举报