iOS编码规范(简版)
1. 总体指导原则
说明:这是软件开发的基本要点,软件的生命周期贯穿产品的开发、测试、生产、用户使用、版本升级和后期维护等长期过程,只有易读、易维护的软件代码才具有生命力,所以提倡写代码之前多思考,特别是逻辑复杂或者技术难点较高的地方,个人思考不清楚的,可以和团队成员进行沟通。
说明:简单是最美。保持代码的简单化是软件工程化的基本要求。不要过分追求技巧,否则会降低程序的可读性。
说明:编程首先考虑的是满足正确性、健壮性、可维护性、可移植性等质量因素,最后才考虑程序的效率和资源占用。
说明:不可以测试的代码是无法保障质量的,开发人员要牢记这一点来设计、编码。实现设计功能的同时,要提供可以测试、验证的方法。
说明:方法是一个处理单元,是有特定功能的,所以应该很好地规划方法,不能是所有东西都放在一个方法里实现,也不能把所有东西都放在一个类里面实现(比如说VC)。
【规则1-7】建议少用XIB,特别是XIB中的约束。
2.控制器规范
【规则2-2】头文件中对外提供的API,建议以方法参数的方式,不建议采用属性的方式。
说明:这是因为采用属性的方式,如果该控制器调用地方较多,每个地方的参数不一样,会造成调用方属性赋值的困惑。
【规则2-4】控制器一般承载较多的逻辑处理,因此对控制器的文件结构做如下规范:
- 头文件
文件头 #import (依次为标准库头文件、非标准库头文件) 宏定义 全局数据类型 类定义
- 实现文件
文件头 #import (依次为标准库头文件、非标准库头文件) 文件内部使用的宏 文件内部使用的数据类型 全局变量 本地变量(即静态全局变量) 类的实现 #pragma mark - LifeCycle #pragma mark - Private Method #pragma mark -- UI #pragma mark -- 数据加载和解析 #pragma mark - Event #pragma mark - Delegate #pragma mark -- UITableViewDataSource #pragma mark -- UITableViewDelegate #pragma mark - Getter/Setter
3.命名规范
说明:
- 小驼峰法:除第一个单词之外,其他单词首字母大写;
- 大驼峰法:把第一个单词的首字母也大写。
说明:以家庭医生服务页为例,前缀为GofFamilyDoctor,描述为Service,类型为ViewController,那么该类命名为GofFamilyDoctorServiceViewController。
关于类型,主要有如下几类:
|
描述
|
类型
|
|---|---|
| 控制器 | ViewController |
| 表格行 | Cell |
| 视图 | View |
| 模型 | Model |
| 数据请求 | DataHelper |
说明:比如定义一个姓名的标签,描述为name,类型为Label,命名为nameLabel。
关于类型缩写,主要有如下两大类:
一、Foundation类型
|
Foundation类型 |
缩写
|
|---|---|
| NSString | String |
| Integer/int | Int |
| BOOL/Boolean | Bool |
| char | Char |
| NSArray | Array |
| NSDictionary | Dic |
| NSDate | Date |
| NSObject | Obj |
二、UIKit类型
|
UIKit类型
|
简写
|
UIKit类型
|
简写
|
|---|---|---|---|
| UILabel | Label | UIButton | Btn |
| UITextView | TextView | UITextField | TextField |
| UITableView | TableView | UIImageVIew | ImageView |
| UIWebView | WebView | UIScrollView | ScrollView |
| UIViewController | VC | UITableViewCell | Cell |
- 方法的名称应全部使用有意义的单词组成,读起来像一句完整的话,能让人从名字就能知道方法的作用;
- set方法前需要添加set,get方法前不需要添加get;
- 常用的方法命名应该使用约定的动词,如initWith、insert、remove、replace等;
- init方法应该遵循Apple命名规则,返回类型使用 instancetype而不是id;
- 方法签名中,应该在方法类型(-/+ 符号)之后有一个空格。在方法各个段之间应该也有一个空格。
typedef NS_OPTIONS(NSInteger, MASAttribute) {
MASAttributeLeft = << NSLayoutAttributeLeft,
MASAttributeRight = << NSLayoutAttributeRight
};
说明:
- 模块可分为公用模块和私有模块,可自定义模块的缩写,比如说公用模块的导航栏,可以定义缩写为nav;
- 功能根据具体的用途划分,比如说返回按钮,功能可定位为back;
- 类型主要有几类:如背景(bg),按钮(btn)等。
综上所述,如果是导航栏的返回按钮,可命名为nav_back_btn@2x.png。
4.注释
【规则4-1】注释建议统一使用VVDocument插件。
【规则4-2】每个头文件必须添加注释,用于对该类的功能做说明。
【规则4-3】头文件中定义的属性和方法,必须添加注释。
说明:属性的注释建议在属性后使用“//<!”添加。
【规则4-5】实现文件中系统方法或系统代理,不强制添加注释。
【规则4-6】实现文件方法中,对功能段代码添加注释,比如说一个视图的定义和属性设置,那么可以作为一个功能段添加注释。
【规则4-7】枚举类型、宏定义、结构体等建议添加注释。
iOS编码规范(简版)的更多相关文章
- iOS编码规范参考
目录 注释 1.1 多行注释 1.2 单行注释 1.3 函数的注释 命名 2.1 常量的命名 2.2 函数的命名 2.3 变量的命名 2.3.1 成员变量 2.3.2 公 ...
- C#代码规范(简版)
C#项目代码规范 目的 1.方便代码的交流和维护. 2.不影响编码的效率,不与大众习惯冲突. 3.使代码更美观.阅读更方便. 4.使代码的逻辑更清晰.更易于理解. 在C#中通常使用的两种编码方式如下 ...
- iOS编码规范
The official raywenderlich.com Objective-C style guide. This style guide outlines the coding con ...
- iOS 编码规范
Coding Guidelines for Cocoa https://developer.apple.com/library/prerelease/content/documentation/Coc ...
- iOS 注释的5要3不要和编码规范的26个方面
注释 代码注释,可以说是比代码本身更重要.这里有一些方法可以确保你写在代码中的注释是友好的: 不要重复阅读者已经知道的内容 能明确说明代码是做什么的注释对我们是没有帮助的. // If the col ...
- Objective-C编码规范:26个方面解决iOS开发问题
介绍 我们制定Objective-C编码规范的原因是我们能够在我们的书,教程和初学者工具包的代码保持优雅和一致.即使我们有很多不同的作者来完成不同的书籍. 这里编码规范有可能与你看到的其他Object ...
- 学习笔记之Python最简编码规范
Python最简编码规范 - 机器学习算法与Python学习 https://mp.weixin.qq.com/s/i6MwvC4jYTE6D1KHFgBeoQ https://www.cnblogs ...
- 【安全开发】IOS安全编码规范
申明:本文非笔者原创,原文转载自:https://github.com/SecurityPaper/SecurityPaper-web/blob/master/_posts/2.SDL%E8%A7%8 ...
- Python最简编码规范
前言 本文是阅读<Python Coding Rule>之后总结的最为精华及简单的编码规范,根据每个人不同喜好有些地方会有不同的选择,我只是做了对自己来说最简单易行的选择,仅供大家参考. ...
随机推荐
- Jmeter正则表达式提取器(转载)
转载自 http://blog.csdn.net/qq_35885203 使用jmeter来测试时,经常会碰到需要上下文传输数据的情况,如登录后生成的token,在其他页面的操作,都需传入这个toke ...
- Citrix XenApp登录服务器过程详解
详细流程: 1. 客户端上的receiver负责解析ICA文件,并根据ICA文件的内容发起连接请求.若是外网访问,则ICA文件中记录的是NetScaler的AG FQDN信息,连接请求发至NetSca ...
- String和StringBuilder、StringBuffer的区别
String对象一旦创建之后该对象是不可更改的,但后两者的对象是变量,是可以更改的. String:适用于少量的字符串操作的情况 StringBuilder:适用于单线程下在字符缓冲区进行大量操作的情 ...
- Balls(扔鸡蛋问题)
4554 BallsThe classic Two Glass Balls brain-teaser is often posed as:“Given two identical glass sphe ...
- linux目录与文件权限的意义
现在我们已经知道了Linux系统内文件的三种身份(所有者,用户者,与其他人),知道每种身份都有三种属性(r,w,x),已经能够使用chown,chgrp,chmod去修改这些权限和属性,那么这些文件权 ...
- 26.Hibernate-主键和映射.md
目录 1.复合主键映射 [toc] 2.集合映射 2.1Set集合 2.2其他集合 [toc] 3.集合数据的读取 [toc] 4.一对多和多对一映射 4.1概念 4.2配置和开发 4.2.1关键点 ...
- linux check
建议安装chkrootkit.rkhunter.Lynis.ISPProtect这类安全工具,定期做扫描
- 安装php调试工具 Xdebug的步骤 火狐 phpstorm联调
一 安装服务器端 1 选择你的版本 <?php phpinfo(); ?> 比如我的: 关键是这三项:PHP Version 7.3.0Architecture x86 (x86是32位系 ...
- extentReport生成测试报告
之前在使用extentReport生成测试报告的时候,没有加载到相关的css,经检查为下面两个文件没有正确加载 后改变配置,加载本地的css和js文件,目前测试报告正确显示 1.创建TestNg的Re ...
- 转:centos查看实时网络带宽占用情况方法
Linux中查看网卡流量工具有iptraf.iftop以及nethogs等,iftop可以用来监控网卡的实时流量(可以指定网段).反向解析IP.显示端口信息等. centos安装iftop的命令如下: ...