Object-C代码规范

最近在整理代码,所以将以前积累的一些代码规范方面的知识分享出来,希望能对大家编码时有所帮助。一个好的代码风格的重要性,不言而喻,希望大家能重视。

下面是小编在平时积累的,肯定不全面,希望大家积极评论,一起完善。

推荐文档:

https://github.com/oa414/objc-zen-book-cn

https://github.com/onefboy/CodeSpecification


一:工程目录结构规范

1、除了第三方框架中出现警告(也要极力消除警告),代码中不能出现警告。

2、除了注释外,所有的资源命名都用英文,不要用魔术数字、汉字。

3、推荐一个规范的工程目录结构

工程目录结构

     Macro:存放公用头文件比如:URL,宏定义,通知,枚举等等。

     Storage:存放封装HTTP请求和数据库操作文件。

     Resources:存放html、音频、视频、图片等资源文件。

     Extra:存放第三方SDK,如:百度地图SDK,支付宝SDK等等

     Vendors:存放工程中封装的一些公用方法 或 SDK。

     Control:存放网络请求(HTTP)Manager、数据库(DB)操作等类文件。

     View:存放所有自定义界面View。

     Model:负责解析HTTP下来的数据。

     Controller:存放所有控制器类。

4、所有的ViewController都应继承自一个BaseViewController(大家懂的)。

5、文件命名、类名应以相应模块英文单词为准,不要用魔术数字命名,比如:

Controller目录

6、所有的公用类头文件声明,放在一个.h头文件里面(比如:宏定义、枚举、URL、第三方账号、一些公用配置参数)。

7、所有第三方账号都用宏定义表示,方便修改、维护。

8、StoryBoard使用:界面跳转用代码实现,不用拖关系线条,方便后期维护。

9、界面适配,建议用Auto Layout放弃Autoresizing,随着大屏iPhone推出,苹果主推Auto Layout技术。

10、所有的类名和主要方法,要加注释。

11、所有的公用方法,都抽成一个公用类里。

12、不要用虚拟目录,如果需要在工程中添加新的文件夹,使用 Add File To 方法添加。


二:代码规范

1、声明类或方法时,注意空格的使用,参数过多时可换行保持对齐。

- (void)registerWithUserName:(NSString *)userName

                              passowrd:(NSString *)password

                                     code:(NSString *)code;

2、调用方法时也是如此,参数都写在一行或换行冒号对齐,

UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"提示"

                                                                         message:@"确认注册?"

                                                                         delegate:nil

                                                            cancelButtonTitle:@"取消"

                                                            otherButtonTitles:@"确认", nil];

3、命名规则

类名首字母大写,方法名首字母小写,方法中的参数首字母小写,同时尽量让方法的命名读起来像一句话,能够传达出方法的意思。

4、变量名小写字母开头,常用驼峰命名,如:userName。

5、写 delegate 的时候类型应该为 weak 弱引用,以避免循环引用,当 delegate 代理的对象不存在时,delegate 没有抢引用对象也就销毁了。

@protocol LoginDelegate

- (void)login;

@end

@interface Delegate : UIViewController

// 使用 weak 弱引用,避免循环引用

@property (weak, nonatomic) id delegate;

@end

6、建议使用“#pragma mark”,方便阅读代码。

#pragma mark - Register Method

7、不要使用魔术数字命名

@property (strong, nonatomic) UIButton *oneButton;

@property (strong, nonatomic) UIButton *twoButton;

8、属性命名不要使用下划线命名方式, 使用驼峰风格。与系统保持一致

// 错误命名

@property (strong, nonatomic) NSString *end_time;

// 正确命名

@property (strong, nonatomic) NSString *endTime;

9、枚举类型的命名规则和函数的命名规则相同:命名时使用驼峰命名法,勿使用下划线命名。

typedef NS_ENUM(NSUInteger, LoginformType) {

     LoginformTypeTel                 = 1,

     LoginformTypeEmail               = 2,

     LoginformTypeSinaWeibo           = 3,

     LoginformTypeWechat              = 4,

     LoginformTypeQQ                  = 5,

};

10、一些非负数整形的数据建议用NSUInteger

@property (assign, nonatomic) NSUInteger age;// 年龄

11、头文件的引用:将系统头文件放在前面,自定义的头文件放在后面,中间可以换行。

##import <UIKit/UIKit.h>

#import "MemberVariable.h"

12、定义的变量要使用,不然会有警告,不要忽视这样警告.

13、关于大括号,代码块的使用,:

大括号内的对象是有生命周期的,对象的作用域在大括号里,出了大括号里面的对象就被释放掉了。

巧妙的使用大括号,可以使得代码更清晰整洁、高效。

14、三个叹号或者问号可以着重标记,可以方便快速查找

// !!!: 宏的使用

// ???: 方法的调用

15、变量命名规则

- 字符串后加     Str

- 集合后加     Array

- 字典后加     Dict

- Label后加     Label

- UIImageView后加     Img

- UIImage后加     Image

- 这时你会发现规律,在变量名后加的都是类型说明符的后缀。

16、 除了初始化方法(init、initWithCoder等)、dealloc方法和自定义的 setters 和 getters 内部,应避免直接访问实例变量。

// ---------------------- VC方法规范 ----------------------

*  1.第一区块viewDidLoad等方法

- (void)viewDidLoad {

     [super viewDidLoad];

     // Do any additional setup after loading the view.

}

- (void)viewWillAppear:(BOOL)animated {}

- (void)viewDidAppear:(BOOL)animated {}

- (void)viewWillDisappear:(BOOL)animated {}

- (void)viewDidDisappear:(BOOL)animated {}

#pragma mark - Private Methods

- (void)register {

}

#pragma mark - UITableViewDataSource

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {

    return 0;

}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

     return 0;

}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier<#@"reuseIdentifier"#> forIndexPath:indexPath];

     // Configure the cell...

     return cell;

}

#pragma mark - UITableViewDelegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath

{

     // do something

}

#pragma mark - CustomeDelegate

-(void)didSelectView....

#pragma mark - Event Action

-(IBAction)buttonDidTouchUpInside:(id)sender{}

#pragma mark - Getters And Setters


17、条件判断

BOOL isLogIn;

if (isLogIn == YES) {// 反对

     NSLog(@"登录成功!");

}

if (isLogIn == YES) // 反对

     NSLog(@"登录成功!");

if (isLogIn) {// 推荐

     // 登录成功

}

if (!isLogIn) {// 推荐

    // 登录失败

}

18、在方法签名中,在 -/+ 符号后应该有一个空格,方法片段之间也应该有一个空格。

- (void)loginWithUserName:(NSString *)userName passowrd:(NSString *)password;

+ (void)loginWithUserName:(NSString *)userName passowrd:(NSString *)password;

19、变量声明

@interface MemberVariable ()

{

     // NSArray *_dataList;// 反对

}

// 推荐

@property (strong, nonatomic) NSArray *dataList;

20、变量限定符

当涉及到在 ARC 中被引入变量限定符时,限定符 (__strong, __weak, __unsafe_unretained, __autoreleasing) 应该位于星号和变量名之间,如:NSString * __weak text。

21、字面量(快速创建)

每当创建 NSString, NSDictionary, NSArray,和 NSNumber 类的不可变实例时,都应该使用字面量。要注意 nil 值不能传给 NSArray 和 NSDictionary 字面量,这样做会导致崩溃。

推荐:

NSArray *names = @[@"Brian", @"Matt", @"Chris", @"Alex", @"Steve", @"Paul"];

NSDictionary *productManagers = @{@"iPhone" : @"Kate", @"iPad" : @"Kamal", @"Mobile Web" : @"Bill"};

NSNumber *shouldUseLiterals = @YES;

NSNumber *buildingZIPCode = @10018;

反对:

NSArray *names = [NSArray arrayWithObjects:@"Brian", @"Matt", @"Chris", @"Alex", @"Steve", @"Paul", nil];

NSDictionary *productManagers = [NSDictionary dictionaryWithObjectsAndKeys: @"Kate", @"iPhone", @"Kamal", @"iPad", @"Bill", @"Mobile Web", nil];

NSNumber *shouldUseLiterals = [NSNumber numberWithBool:YES];

NSNumber *buildingZIPCode = [NSNumber numberWithInteger:10018];

22、当访问一个 CGRect 的 x, y, width, height 时,应该使用CGGeometry 函数代替直接访问结构体成员。

CGRect frame = self.view.frame;

CGFloat x = CGRectGetMinX(frame);

CGFloat y = CGRectGetMinY(frame);

CGFloat width = CGRectGetWidth(frame);

CGFloat height = CGRectGetHeight(frame);

// 不推荐

CGRect frame2 = self.view.frame;

CGFloat x2 = frame.origin.x;

CGFloat y2 = frame.origin.y;

CGFloat width2 = frame.size.width;

CGFloat height2 = frame.size.height;

23、如果一个 BOOL 属性名称是一个形容词,属性可以省略 “is” 前缀,但为 get 访问器指定一个惯用的名字,例如:

@property (assign, getter=isEditable) BOOL editable;

24、单例对象应该使用线程安全的模式创建共享的实例。

+ (instancetype)sharedInstance {

     static id sharedInstance = nil;

     static dispatch_once_t onceToken;

     dispatch_once(&onceToken, ^{

          sharedInstance = [[self alloc] init];

     });

     return sharedInstance;

}

26、Xcode 工程

为了避免文件杂乱,物理文件应该保持和 Xcode 项目文件同步。Xcode 创建的任何组(group)都必须在文件系统有相应的映射。为了更清晰,代码不仅应该按照类型进行分组,也可以根据功能进行分组。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,569评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,499评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,271评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,087评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,474评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,670评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,911评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,636评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,397评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,607评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,093评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,418评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,074评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,092评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,865评论 0 196
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,726评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,627评论 2 270

推荐阅读更多精彩内容