小技巧三:iOS代码规范

Version:1.0.0

Objective-C工程及代码规范

一、工程总述

1.工程名称为英文

工程名称必须为英文,不能使用中文、特殊符号、其他语言,不推荐使用汉语拼音、阿拉伯数字、下划线(特殊情况除外:客户特别要求的情况、使用英文过于繁琐的情况、工程名存在版本号的情况)。

2.上传SVN服务器要求

上传到SVN服务器之前要新建一个文件夹,并将工程文件夹放入到新建的文件夹中。上传到SVN服务器时,应当把新建的文件夹上传而非工程文件夹。

例如:

图1.1上传工程到SVN服务示例

图1.1中当需要上传testForStandard这个工程到SVN服务器时,需要将工程的根目录testForStandard单独放在一个新的文件夹testForStandardsvn中,将testForStandardsvn上传到SVN服务器。

图1.2文件压缩示例

当从svn上单独下载某一个工程后,如需压缩源码,只需要将工程文件夹压缩,而不要将与工程文件夹平行的.svn文件夹一起压缩。如图1.2所示(显示Mac隐藏文件的命令:defaults write com.apple.finder

AppleShowAllFiles YES隐藏Mac隐藏文件的命令:defaults write com.apple.finder AppleShowAllFiles NO)

二、工程目录规范

1.目录总述

1)所有文件夹为真实文件夹

所有新创建的目录必须为真实文件夹(即在Finder中创建,而非在Xcode工程中直接New Group)。

2)文件夹需要彻底删除

当在Xcode中删除某一个文件夹以及文件夹中的文件时,必须要在Finder中将残留的空文件夹删除。防止出现文件夹重名和文件夹残留。

2.目录要求

1)总体要求(举例)

图2.1工程主目录示例

在工程根目录中需要存在Class、Image、Libs、Share这几个文件夹。.h和.pch文件需要放在AppDelegate文件的下边。工程自动生成的文件不需要改变位置。

2)class文件夹要求

图2.2 class目录示例

建议在class下面存在两层子模块。在最子模块中进行model、view、controller分类,如有必要可以添加一个other目录。

3)image、Libs、目录要求

image目录中存放图片,每个模块添加一个子文件件进行分类。

Libs目录中只能存放文件夹,不允许存放单独文件,为后续维护提供便利,另外,所有第三方之间不能横向耦合(除几个最常用的外),即A第三引用B第三方的东西,如有相互引用,需要进行解耦。

4)share目录要求

图2.3 share目录示例

只允许存在文件夹。几乎所有的公共类或者模块都需要放在该目录中。如有必要可以在某个子目录中进行mvc的划分。

三、命名规范

1.类命名要求

①所有类名使用JY开头(个人封装除外)。

②除非万不得已或者客户要求的情况下,使用英文命名。

③除了非常常见且比较长的单词之外,不得使用英文缩写。

④杜绝使用纯粹的first、second这类单词命名。

⑤尽可能不适用myCell、myView这种模式。

⑥model以及model的子类应当以Model结尾

⑦UIViewController及其子类应当以ViewController结尾

⑧UITableViewCell及其子类应当以Cell结尾

⑨封装的view及其封装的子类应当以View结尾

2.宏定义命名要求

1)接口

所有接口必须以URL_开头

网络请求的域名需要使用宏定义,宏名称为URL_REQUEST。这里的域名不包括任何参数,所有参数都进行单独拼接。例如:

#define URL_REQUEST @”http://www.baidu.com

如有图片的相对路径需要进行拼接,需要将拼接的公共部分进行宏定义,宏名为URL_IMAGE。例如:

#define URL_IMAGE @”http://www.baidu.com/image

如有必要可以单独添加其他公共接口。

2)Key

将所有的与整个app相关的key和秘钥都进行宏定义。所有的key的定义必须以KEY_开头。例如:

#define KEY_RONGCLOUD @”xxxxxxxxx”

#define KEY_BAIDUMAP @”xxxxxxxxx”

#define KEY_UMENG @”xxxxxxxxx”

3)颜色

app中公共使用或者多处使用到颜色需要使用宏定义。例如:

#define RGBA(r,g,b,a) [UIColor colorWithRed:r/255.0f green:g/255.0fblue:b/255.0f alpha:a]

#define colorOfNav xxxxxx

#define colorOfTabBar xxxxxx

4)版本判定

可以根据需要定义版本

5)UI界面尺寸

#define HOfScreen [UIScreen mainScreen].bounds.size.height

#define WOfScreen [UIScreen mainScreen].bounds.size.width

#define HOfNavBar self.navigationController.navigationBar.frame.size.height

#define HOfTabBar self.tabBarController.tabBar.frame.size.height

6)其他常量的宏定义

建议使用extern和const修饰的常量替代宏定义。

3.变量命名要求

①变量名必须有意义。

②全局变量必须以_开头。

③全局变量和属性名称建议使用控件名的缩写和功能的组合。例如:

@property (nonatomic, strong)UILabel *lbTitle;

UILabel *_lbTitle;

@property (nonatomic, strong)UIButton *btnSubmit;

UIButton *_btnSubmit

@property (nonatomic, strong)UIImageView *imgvPortrait;

UIImageView *_imgvPortrait;

@property (nonatomic, strong)UITextField *tfUserName;

UITextField *_tfUserNamel;

@property (nonatomic, strong)UITextView *tvDetail;

UITextView *_tvDetail;

④对于一些特殊类型的变量,命名时要带上类型,如NSArray的变量命名为xxxArray,其他的如xxxDictionary,xxxSize等。这样就可以从名称上知道是什么类型的变量。千万不能将NSArray的变量命名为xxxDictionary。(这里的类型的单词可以适当缩写)

4.方法命名要求

①所有方法使用英文名,遵守驼峰命名规则。开头小写。

②所有方法名必须有实际意义。

5.图片命名要求

图3.1美工图片命名

图片命名基本按照图3.1规则来。使用缩写和下划线组合。必须在文件名后加上合适的后缀(@2x、@3x)。

四、代码实现要求

1.总体规划

尽可能少的将变量函数做为共有的。

对网络请求需要进行进一步的高度封装,达到只需要执行一个方法就能够实现网络请求的发送,可以基于代理也可以基于block,建议使用block。

用户信息需要在一个单例中存储便于读取。如果有必要需要将用户信息存储到本地,并且在每次程序运行时讲本地存储的用户信息以及其他相关数据读取到单例中,在需要时从单例中读取。

视图中小控件集中分布的或者相对于其他控件是独立的模块的区域建议进行单独封装,便于管理和查找。

2.用于给多人使用的公有方法的声明

/**

*POST请求

*@param urlString请求网址

*@param parameters请求参数

*@param tag请求的标识

*@param stop是否停止其他请求队列

*@param serializer是否取消自动解析

*@param success请求成功回调方法

*@param failure请求失败回调方法

*/

- (void)POST_withUrlString:(NSString *)urlString

parameters:(id)parameters

stopOtherRequest:(BOOL)stop

withSerializer:(BOOL)serializer

success:(void(^)(AFHTTPRequestOperation *operation, id responseObject))success

failure:(void (^)(AFHTTPRequestOperation *operation, NSError*error))failure;

3.类中方法的实现的分类

每个类的.m文件都需要对文件内所有的方法进行合理的分类,并将每一类方法使用#param mark – xxxxxx分割。示例分类:

准备:一些数据的初始化(包括属性和全局变量)

UI创建和初始化:UI视图的第一次创建和初始化配置

UI逻辑:视图的现实隐藏操作、视图的大小变化、视图的offset或者其他视图逻辑

事件处理方法:一些button的各种事件的处理方法、各种手势的处理方法

回调方法:代理方法,非主动调用的方法,建议再对回调方法根据协议或者作用使用#param mark xxxx分割。例如:tableview的所有方法都写在#param mark tableViewDelegate的下边。

五、代码细节要求

1.除常见方法外都需要写注释说明方法的作用,有返回值的需要说明返回值的作用。

2.写方法时当参数过长、过多时,每个参数占用一行,以冒号对齐。如:

- (void)writeFisrtNumber:(NSString *)firstStr

withNextNumber:(NSString *)nextStr

withLastNumber:(NSString *)lastStr

{}

如果方法名比参数名短,每个参数占用一行,至少缩进4个字符,且为垂直对齐(而非使用冒号

对齐)。如:

//实际上是对齐的,copy过来后有些变形

- (void)writeA:(NSString *)firstStr

withBBBBBBBBBBB:(NSString *)nextStr

withCCCCCC:(NSString *)lastStr

{}

3.Model基类需要命名为LXBaseModel,在这个类中需要实现防止键值不匹配的方法

4.用户信息的存储:

使用单例进行存储。单例名称统一为LXSingleInfo,单例的获取方法名为shareInfo。使用GCD写单例获取方法。

5.协议的遵守建议在.m文件中遵守。非公开属性建议在.m文件中声明。

6.通知需要注销。如有必要将delegate置nil。防止通知错乱和野指针错误出现。

7.代码中多次出现的常量建议使用宏定义或者定义成const修饰的常量。便于多处一起修改。

8.长字符串(超过10行)的打印测试过之后建议注释掉。解决因打印引起的运行速度慢问题。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,799评论 25 707
  • iOS编程规范0规范 0.1前言 为􏰀高产品代码质量,指导广大软件开发人员编写出简洁、可维护、可靠、可 测试、高效...
    iOS行者阅读 4,446评论 21 35
  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,131评论 30 470
  • 在我感情的封锁区 有关于你 绝口不提 没限期 在一个星期里我听到了两个故事,都来自陈小春的独家记忆。一个是我的好闺...
    珊贝勒阅读 349评论 0 2