命名规范
类命名
    首字母大写,之后每个单词首字母都大写
    使用能够反映类功能的名词短语
    文件和类同名
    举例:BaseClient、ImageStore
特殊类命名
    如果是视图控制器的子类应添加后缀“ViewController”或者“Controller”
    如果是视图的子类应添加后缀“View”
    如果是按钮的子类应添加后缀“Button”
……
    举例:SettingsViewController、NavigationView
分类(类别)命名
    与类命名相同,此外需添加要扩展的类名和“+”
    举例:NSString+URLEncoding
协议(委托)命名
    与类命名相同,此外需添加“Delegate”后缀
    举例:ReplyViewDelegate
方法命名
    首字母小写,之后每个单词首字母都大写
    方法名使用动词短语
    举例:- (void)setPostValue:(int)value
方法参数命名
    首字母小写,之后每个单词首字母都大写
    具有足够的说明性
    不需要添加类型前缀
    举例:- (void)sendUserInfo:(NSDictionary *)userInfo
变量命名
    首字母小写,之后每个单词首字母都大写
    具有足够的说明性
    成员变量不需要添加“_m”前缀
    成员变量添加“_”前缀
常量
    常量(预定义,局部常量等)使用小写k开头的驼峰法
    举例:kInvalidHandle , kWritePerm
    枚举类型命名首字母大写,之后每个单词首字母都大写,最后加“s”
    枚举变量使用枚举类型去掉“s”作为前缀,每个单词首字母大写,中间不允许加下划线
    举例:
typedef enum UIControlEvents{
UIControlEventTouchDown,
UIControlEventTouchUpInside
}UIControlEvents;
图片命名
    使用英文,首字母大写,之后每个单词首字母都大写
    添加模块名作为前缀,避免冲突
    图片应该与类文件一样,按模块分组放置
分组命名
    使用英文,首字母大写,之后每个单词首字母都大写
    每个分组使用模块的名字
    使用的开源库统一放在“Library”分组下
    使用的公共组件统一放在“Common”分组下
    视图控制器及AppDelegate统一放在“Controllers”分组下
书写规范
注释
    文件都包含文件头,要说明文件名、作者、创建时间、变更记录
    多人协作完成项目时,public接口的每个方法都应该添加关于函数,参数,返回值以及副作用的注释
    if语句的判断条件复杂时,需要用注释说明判断内容
    接口类(继承于BaseClient)的头文件每个方法前都应该注明方法的作用
方法
    留一个空格在-或+和返回类型之间,但参数列表里的参数之间不要留间隔,每个冒号之前都必须有对该参数的说明词,如:
p - (void)doSomethingWithString:(NSString *)string number:(int)num
    如果参数过多,推荐每个参数各占一行。使用多行的情况下,在参数前加冒号用于对齐,如:
p  -(void)doSomethingWith:(GTMFoo *)theFoo
                                          rect:(NSRect)theRect
                             interval:(float)theInterval
其他规范
    操作符前后都要加空格
    避免相同的代码段在多个地方出现
    语句嵌套层次不得超过3层
    每个实现文件建议在500行以内,不能超过1000,超过之后应考虑通过抽象类对代码进行重构
    及时删除或注释掉无用的代码
    UITableViewCell里面的network client都要委托出来
    点击按钮之后需要切换按钮图片,当这两张图片没有关联时(例如一张图片相比另一张图片有选中效果),不应该设置为UIControlSelected
    控件布局使用相对坐标
    确定不使用的代码应该删除


iOS代码规范之命名规范的更多相关文章

  1. python代码规范和命名规范

    一.简明概述 1.编码 如无特殊情况, 文件一律使用 UTF-8 编码 如无特殊情况, 文件头部必须加入#-*-coding:utf-8-*-标识 2.代码格式 2.1.缩进 统一使用 4 个空格进行 ...

  2. C#中的代码书写规范以及命名规范

    C#代码书写规则: 1. 尽量使用接口,然后使用类实现接口,以提高程序的灵活性. 2.一行不要超过80个字符 3.尽量不要手动更改计算机生成的代码 4.关键的语句写注释 5.建议局部变量在最接近使用它 ...

  3. python基础(代码规范、命名规范、代码缩进、注释)

    代码规范 PEP8(python增强建议书第8版) 每个import语句只导入一个模块 不要在行尾添加分号";" 建议每行不超过80个字符   超出部分可以用()来进行换行例如: ...

  4. [置顶] Objective-C ,ios,iphone开发基础:命名规范

    命名规范:http://bukkake.iteye.com/blog/695492  点击打开链接

  5. 浅谈Android编码规范及命名规范

    前言: 目前工作负责两个医疗APP项目的开发,同时使用LeanCloud进行云端配合开发,完全单挑. 现大框架已经完成,正在进行细节模块上的开发 抽空总结一下Android项目的开发规范:1.编码规范 ...

  6. CSS书写规范、命名规范、网易CSS框架NEC

    网易CSS框架NEC:http://nec.netease.com/ NEC框架的CSS规范:  CSS规范 - 分类方法 CSS规范 - 命名规则 CSS规范 - 代码格式 CSS规范 - 优化方案 ...

  7. PHP Document 注释标记及规范 && PHP命名规范

    注释标记 @access 使用范围:class,function,var,define,module 该标记用于指明关键字的存取权限:private.public或proteced @author 指 ...

  8. 前端开发规范:命名规范、html 规范、css 规范、js 规范

    上周小组的培训内容是代码可读性艺术,主要分享如何命名.如何优化代码排版,如何写好的注释.我们都知道写出优雅的代码是成为大牛的必经之路. 下面感谢一位前端开发小伙伴总结的前端开发规范,通过学习相关开发规 ...

  9. Java 编程规范,常见规范,命名规范,复杂度

    方法/步骤     1. *不允许把多个短语句写在一行中,即一行只写一条语句 1. 示例:如下例子不符合规范. LogFilename now = null;        LogFilename t ...

随机推荐

  1. [文章存档]Azure上部署的java app在向第三方服务传送中文时出现乱码

    https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/aog-app-service-web-java ...

  2. DRF01

    1.web应用模式 在web开发中有两种应用模式: 1)前后端不分离 2)前后端分离 2.api接口 为了在团队内部形成共识.防止个人习惯差异引起的混乱,我们需要找到一种大家都觉得很好的接口实现规范, ...

  3. ping命令使用及其常用参数

    PING (Packet Internet Groper),因特网包探索器,用于测试网络连接量检查网络是否连通,可以很好地帮助我们分析和判定网络故障.Ping发送一个ICMP(Internet Con ...

  4. 微软职位内部推荐-SW Engineer II for Azure Network

    微软近期Open的职位: Software Engineer II The world is moving to cloud computing. Microsoft is betting Windo ...

  5. petapoco 对存储过程的扩展 干货

    好久没发表文章了.心血来潮,简单的介绍下这次工作中的问题. 项目中运用了Petapoco,可是petapoco对存储过程的支持不够好.或者说对于某些特殊场景,petapoco的sql支持度有限. 比如 ...

  6. Ajax实例OR技术原理 转自 (http://blog.csdn.net/evankaka )

    摘要:AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术.AJAX 是一种用于创建快速动态网页的 ...

  7. PHP密码的六种加密方式

    1. MD5加密 string md5 ( string $str [, bool $raw_output = false ] ) 参数 str  --  原始字符串. raw_output  --  ...

  8. 20135337朱荟潼 Linux第四周学习总结——扒开系统调用的三层皮(上)

    朱荟潼 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课http://mooc.study.163.com/course/USTC 1000029000 知识点梳理 一.用 ...

  9. page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台乱码问题

    page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台 ...

  10. C#Dictionary使用记录

    一.区别 在工作中经常遇到C#数组.ArrayList.List.Dictionary存取数据,其区别和优劣势为: 初始化 数组: int[] buff = new int[6]; ArrayList ...