一、OC特性

  • OC 为 C 语言添加了面向对象特性,是其超集;
  • OC 使用动态绑定的消息结构,也就是,在运行时才会检查对象类型;
  • 接收一条消息后,究竟应执行何种代码,由运行期环境来决定,而非 编译器;
  • ps:理解C语言的核心概念有助于写好OC程序,尤其 要掌握 内存模型 与 指针。

二、在类头文件中尽量少引入其他头文件

  • 除非有必要,否则不要引入头文件。一般来说,应在某个类的头文件中使用 向前声明(@class MEPerson;)来提及别的类,并在实现文件中引入那些类的头文件。这样做可以尽量降低类之间的耦合(couping);
  • 有时无法使用 向前声明(@class MEPerson;),比如要声明某个类遵循意向协议。 这种情况下,尽量把 “该类遵循某协议” 的这条声明 移至 “分类Category” 中。如果不行的话, 就把协议单独放在一个头文件中,然后将其引入。

三、多用字面量语法,即简写语法

  • 繁:NSNumber *num = [NSNumber numberWithInt:1];
  • 简:NSNumber *num1 = @1;
  • 好处:能够以nsNumber 实力表示的所有数据类型都可以用该语法

      NSNumber *intNum = @1;

      NSNumber *floatNum = @2.5f;

       NSNumber *doubleNum = @3.14159;

       NSNumber *boolNum = @YES;

       NSNumber *charNum = @'a’;

  更加简便的语法: 

       int x = ;

      float y = 6.32f;

       NSNumber *expressionNum = @(x * y);

1>数组

  • 繁:NSArray *animals = [NSArray arrayWithObjects:@"cat", @"dog",@"mouse",@"badger" ,nil];   //(这种写法,如果有值是nil ,会抛出异常)
  • 简:NSArray *animals1 = @[@"cat", @"dog",@"mouse",@"badger"];
  • 繁: NSString *dog = [animals objectAtIndex:1];
  • 简: NSString *gog1 = animals[1];
  • 异常抛出:insert nil object from objects[0](如果有值是nil)
  • 原因:arrayWithObjects: 方法会依次处理各个参数,直到发现nil为止;
  • 从这角度看,简写会比较安全

    2>字典

实例

  • 繁: NSDictionary *personData =  [NSDictionary dictionaryWithObjectsAndKeys:
                                @"rose",@"fistName",
                                @"may",@"lastName",
                                [NSNumber numberWithInt:28],@"age",
                                nil];
  • 简: NSDictionary *personData1 =      
  •                                        @{@"rose": @"fistName",           
        •   @"may" : @"lastName",               
        •         @"age" : @28 };

取值

  • 繁:NSString *lastName = [personData objectForKey:@"lastName"];
  • 简:NSString *lastName1 = personData1[@"lastName”];

可变数组和字典

  • 繁: [NSMutableArray replaceObjectAtIndex:1 withObject:@"dog"];
  • 简: NSMutableArray[1] = @"dog";
  • 繁:[NSMutableDictionary setObject:@"rose" forKey:@"lastName"];
  • 简: NSMutableDictionary[@"lastName"] = @"rose”;

小小限制:除了字符串以外,所创建出来的对象必须属于Foundation框架才行;

如果自定义了这些子类,则无法用字面量语法创建其对象。

以上都是不可变的,需要可变 则需要复制一份

NSMutableArray *mutable = [@[@1, @2, @3, @4, @5]mutableCopy];

要点:

  • 应该使用字面量语法来创建字符串、数值、数组、字典。 与创建此类对象的常规方法相比,这么做更加简明扼要;
  • 应该通过取下标操作来访问数组下标或字典中得键 所对应的元素;
  • 用字面量语法创建数组或自在点时,若值中有nil,则会抛出异常。因此,务必确保值里不含nil.

4.多用类型常量,少用#define预处理指令

少用:#define ANIMATION_DURATION 0.3

最好用:

// 变量一定要同时用static 与 const 来声明。只在.m使用

// MEView.h

// MEView.m

static const NSTimeInterval MEAnimationDuration1 = 0.3;

// 需要对外公布使用

例子1:

// MEView.h

extern const NSTimeInterval MEAnimationDuration;

// MEView.m

const NSTimeInterval MEAnimationDuration = 0.3;

例子2:

// MEView.h

extern NSString *const MEStringConstant;

// MEView.m

NSString *const MEStringConstant = @"VALUE”;

要点:

  • 不要使用预处理指令定义常量。这样定义 出来的常量不含类型信息,编译器只是会在编译前据此执行查找与替换操作。即使有人重新定义了常量值,编译器也不会产生警告信息,这将导致应用程序中的常量值不一致;
  • 在实现文件中使用 static const 来定义“只在编译单元内可见的常量(translation-unit-specific constant)”. 由于此类常量不在全局常量表中,所以无需为其名称加前缀;
  • 在头文件中使用extern 来声明全局常量,并在相关市县文件中定义其值。 这种常量要出现在全局符号表中,所以其名称应加以区隔,通常用 和他相关的类名做前缀。

5.用枚举表示状态、选项、状态码

由于OC 基于C语言, 所以C语言有的功能它都有。

枚举 只是一种常量命名方式。

某个对象所经历的各种状态就可以定义为一个简单的枚举集。如:

  socket connetion

第一种情况:使用系统分配的序号

enum MEConnetionState {

MEConnetionStateDisconnected,

MEConnetionStateConnecting,

MEConnetionStateConnected,

}

由于每种状态都用一个便于理解的值来表示,所以这样写出来的代码更易读懂。编译器会为枚举分配一个独有的编号,从0开始,每个枚举递增1.

第二种情况:可以不使用编译器所分配的序号,而是手工指定某个枚举成员变量所对应的值

enum MEConnetionState {

MEConnetionStateDisconnected = 1,

MEConnetionStateConnecting,

MEConnetionStateConnected,

}

第三种情况:使用枚举类型,就是定义选项时。若这些选项可以彼此组合,则更应如此

enum UIViewAutoresizing {

UIViewAutoresizingNone                 = 0,

UIViewAutoresizingFlexibleLeftMargin   = 1 << 0,

UIViewAutoresizingFlexibleWidth        = 1 << 1,

UIViewAutoresizingFlexibleRightMargin  = 1 << 2,

UIViewAutoresizingFlexibleTopMargin    = 1 << 3,

UIViewAutoresizingFlexibleHeight       = 1 << 4,

UIViewAutoresizingFlexibleBottomMargin = 1 << 5,

}

*只要枚举定义得对,各选项之间就可通过 “按位或操作符”来组合。

*使用上述方式来定义枚举值即可保证,每个选项均可启用或禁用。

*系统库中频繁使用这个方法。

- (NSUInteger)supportedInterfaceOrientations {

return UIInterfaceOrientationMaskPortrait |

UIInterfaceOrientationLandscapeLeft;

}

系统写法(新式语法):

typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {

UIViewAutoresizingNone                 = 0,

UIViewAutoresizingFlexibleLeftMargin   = 1 << 0,

UIViewAutoresizingFlexibleWidth        = 1 << 1,

UIViewAutoresizingFlexibleRightMargin  = 1 << 2,

UIViewAutoresizingFlexibleTopMargin    = 1 << 3,

UIViewAutoresizingFlexibleHeight       = 1 << 4,

UIViewAutoresizingFlexibleBottomMargin = 1 << 5

};

支持新特性,用NS_ENUM 定义:

typedef enum : NSUInteger {

MEConnetionStateDisconnected,

MEConnetionStateConnecting,

MEConnetionStateConnected,

} MEConnetionState;

在switch语句里枚举的用法:

*凡是需要以按位或操作来组合的枚举都应使用NS_OPTIONS定义。若是枚举不需要互相组合,则应使用NS_ENUM 来定义

typedef NS_ENUM(NSInteger, MEConnetionState) {

MEConnetionStateDisconnected,

MEConnetionStateConnecting,

MEConnetionStateConnected,

};

switch (_currentState) {

MEConnetionStateDisconnected:

break;

MEConnetionStateConnecting:

break;

MEConnetionStateConnected:

break;

}

注意:若使用枚举来定义状态机,则最好不要有default分支。

要点:

  • 应该用枚举来表示状态机的状态、传递给方法的选项以及状态码等值,给这些值起个易懂的名字。
  • 如果把传递某个方法的选项表示为枚举类型,而多个选项又可同时使用,那么就将各选项定义为2的幂,以便通过按位或操作将其组合起来。
  • 用NS_ENUM 与 NS_OPTIONS 宏来定义枚举类型,并指明其底层数据类型。这样做可以保证枚举 是用开发者所选的底层数据类型是现实出来的,而不会采用编译器所选的类型。
  • 在处理枚举类型的switch 语句中不要事先default 分支。这样的话,加入新美剧之后,编译器就会提示开发者:swith 语句并未处理所有枚举。

版权所有--kiss小锦(原创)

读Effective Objective-C [提高OC代码质量总结笔记第一篇:熟悉OC]的更多相关文章

  1. iOS 52个技巧学习心得笔记 第一章 熟悉OC

    1 .简单了解OC2 .在类的头文件中尽量少引入其他头文件3 .多用字面量语法 少用与之等价的方法 4 .多用类型常量 少用 #define 预处理指令5 .用枚举表示状态,选项,状态码 .简单了解O ...

  2. 提高Objective-C代码质量心机一:简化写法

    提高OC代码质量的小心机 一.OC特性 OC 为 C 语言添加了面向对象特性,是其超集; OC 使用动态绑定的消息结构,也就是,在运行时才会检查对象类型; 接收一条消息后,究竟应执行何种代码,由运行期 ...

  3. 提高Java代码质量的Eclipse插件之Checkstyle的使用详解

    提高Java代码质量的Eclipse插件之Checkstyle的使用详解 CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发人员遵守某些编码规范的工具.它能够自动化代 ...

  4. 提高 Android 代码质量的4个工具

    在这篇文章中,我将通过不同的自动化工具如CheckStyle,FindBugs,PMD以及Android Lint来介绍(如何)提高你的安卓代码质量.通过自动化的方式检查你的代码非常有用,尤其当你在一 ...

  5. 使用JSLint提高JS代码质量

    随着富 Web 前端应用的出现,开发人员不得不重新审视并重视 JavaScript 语言的能力和使用,抛弃过去那种只靠“复制 / 粘贴”常用脚本完成简单前端任务的模式.JavaScript 语言本身是 ...

  6. 提高Java代码质量的Eclipse插件之Checkstyle的使用具体解释

    CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发者遵守某些编码规范的工具.它可以自己主动化代码规范检查过程.从而使得开发者从这项重要可是枯燥的任务中解脱出来. Ch ...

  7. CODING DevOps 代码质量实战系列第一课:代码规范与 Git Flow

    讲师介绍 杨周 CODING DevOps 架构师 CODING 布道师 连续创业者.DIY/Linux 玩家.知乎小 V,曾在创新工场.百度担任后端开发.十余年一线研发和带队经验,经历了 ToB.T ...

  8. 提高PHP代码质量的36个技巧

    1.不要使用相对路径 常常会看到: require_once('../../lib/some_class.php'); 该方法有很多缺点: 它首先查找指定的php包含路径, 然后查找当前目录. 因此会 ...

  9. 提高php代码质量 36计

    1.不要使用相对路径 常常会看到: ? 1 require_once('../../lib/some_class.php'); 该方法有很多缺点: 它首先查找指定的php包含路径, 然后查找当前目录. ...

随机推荐

  1. ios学习之block初探

    1. block概念 block是ios4.0+和Mac osX 10.6以后引进的对C语言的拓展,用来实现匿名函数的特性.所谓匿名函数,也称闭包函数.即同意创建一个暂时的没有指定名称的函数. 最经经 ...

  2. ORM进阶:Hibernate的优劣对照

    hibernate是一种是轻量级的ORMapping框架.学过EntityFramework的.会感觉挺亲切的. 对于各种层次程序猿对数据库的设计: 小菜程序员这样做:首先考虑数据的存储,对于功能的实 ...

  3. UVALive-6485-Electric Car Rally(BFS)

    题目:点击打开链接 思路:对于当前位置的每个时间段都要走一遍(除了那些须要的时间比最大同意的时间还大的),用 整形 vis[当前位置][剩余油量] 标记. #include <cstdio> ...

  4. Flex 正則表達式 电话、邮箱验证

     一.经常使用验证 验证数字:^[0-9]*$ 验证n位的数字:^\d{n}$ 验证至少n位数字:^\d{n,}$ 验证m-n位的数字:^\d{m,n}$ 验证零和非零开头的数字:^(0|[1-9 ...

  5. js37---Function.prototype

    //给函数的prototype新增名字为name,函数体为fn的函数 Function.prototype.method =function(name,fn){ this.prototype[name ...

  6. ubuntu-虚拟机跟主机资源共享的实现方法

    之前自己的虚拟机跟主机资源共享的时候,使用的是非常笨的方法,就是通过创建两个飞鸽,然后在两个飞鸽之间进行文件的传输,今天工作相对轻松一些,就趁机完善一下自己的工作环境,在网上搜索了关于资源共享的方法, ...

  7. Day5下午解题报告1

    预计分数:100+60+30=190 实际分数:100+60+30=190 终于有一道无脑T1了哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈 ...

  8. RS-485总线和Modbus通信协议的关系

    一.RS-485总线 RS-485总线技术只是规定了接口的电气标准,并没有规定RS-485接口的电缆,插件以及通信协议,只是OSI规范中物理层的一个标准,RS-485总线采用差分平衡传输方式.由于RS ...

  9. 97.TCP通信

    运行截图: 客户端 创建通信套接字 //通信套接字,用于创建TCP连接 SOCKET socket_send; 创建tcp通信 //创建tcp通信 socket_send = socket(AF_IN ...

  10. 1.1 Introduction中 Producers官网剖析(博主推荐)

    不多说,直接上干货! 一切来源于官网 http://kafka.apache.org/documentation/ Producers 生产者(Producers) Producers publish ...