• OC基础(5)


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

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

  • 相关阅读:
    练习1-17 编写一个程序,打印长度大于80个字符的所有输入行.
    练习1-16 修改打印最长文本行的程序的主程序main, 使之可以打印任意长度的输入行的长度, 并尽可能多的打印文本。
    惠普Z620工作站用安装版装win7旗舰版64位结果找不到硬盘
    输入元素( Input Element)
    GradientStop
    qml关键字style
    opacity
    QT5-step-by-step-LayoutManagement
    QT5-step-by-step-BasicKnowledge
    Adeneo Embedded: Building Qt 5.1 for Freescale i.MX6Introduction on LTIB
  • 原文地址:https://www.cnblogs.com/zhoudaquan/p/5014776.html
Copyright © 2020-2023  润新知