ios开发规范文档讲解.docx

  1. 1、本文档共23页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
命名 命名规则对于维护代码来说是非常重要的,。Objective-C方法名往往很长,不过这也有好处,让很多注释变得毫无意义。 本文推荐驼峰法,也是Objective-C社区的标准。? 驼峰法分小驼峰法和大驼峰法。小驼峰法:除第一个单词之外,其他单词首字母大写。大驼峰法相比小驼峰法,大驼峰法把第一个单词的首字母也大写了。 1.基本原则 1.1 清晰 又清晰又简洁是最好的了,但简洁不如清晰重要。总的讲不要使用单词的简写,除了非常常用的简写以外,尽量使用单词全称。API的名称不要有歧义,一看你的API就知道是以什么方式做了什么事情,不要让人有疑问 1.2 一致性 做某个事情代码通常都叫这个名字,比如tag、setStringValue,那么你也这么叫。你在不确定怎么起名字的时候,可以参考一些常用的名字: HYPERLINK /library/mac/documentation/Cocoa/Conceptual/CodingGuidelines/Articles/NamingMethods.html \l //apple_ref/doc/uid1001865 \t _blank Method Arguments 2. 类命名 类名(不包括类别和协议名)应该用大写开头的大驼峰命名法。类名中应该包含一个或多个名词来说明这个类(或者类的对象)是做什么的。 在应用级别的代码里,尽量不要使用带前缀的类名。每个类都有相同的前缀不能提高可读性。不过如果是编写多个应用间的共享代码,前缀就是可接受并推荐的做法了(型如 MBAPhotoBrowser )。 示例1: @interface?ImageBrowseView :UIView @end 示例2:(带前缀MBA) @interface?MBAPhotoBrowser :UIView @end 3. 类别命名 类名+标识+扩展(UIImageView +HP+Web) 例:如果我们想要创建一个基于UIImageView 的类别用于网络请求图片,我们应该把类别 放到名字是UIImageView+HPWeb.h的文件里。UIImageView为要扩展的类名,HP为专属标 识,Web为扩展的功能。 类别的方法应该都使用一个前缀(型如hp_myCategoryMethodOnAString ),以防止Objective- C代码在单名空间里冲突。如果代码本来就不考虑共享或在不同的地址空间(address- space),方法命名规则就没必要恪守了。 类别HPWeb头文件,UIImageView+HPWeb.h如下: @interface?UIImageView (HPWeb) - (void)hp_setImageWithURLString:(NSString?*)urlStr; @end 4. 方法命名? 方法使用小驼峰法命名, 一个规范的???法读起来应该像一句完整的话,读过之后便知函数 的作用。执行性的方法应该以动词开头,小写字母开头,返回性的方法应该以返回的内容 开头,但之前不要加get。 示例: - (void)replaceObjectAtIndex:(NSUInteger)index withObject:(id)anObject; (instancetype)arrayWithArray:(NSArray?*)array; 如果有参数,函数名应该作为第一个参数的提示信息,若有多个参数,在参数前也应该有 提示信息(一般不必加and) ?一些经典的操作应该使用约定的动词,如initWith,insert,remove,replace,add等等。 5. 变量命名? 变量名使用小驼峰法, 使变量名尽量可以推测其用途属性具有描述性。别一心想着少打几 个字母,让你的代码可以迅速被理解更加重要。 5.1 类成员变量: 成员变量用小驼峰法命名并前缀下划线,Objective-C 2.0,@property 和 @synthesize 提供 了遵守命名规范的解决方法 示例: @interface?ViewController?() @property?(nonatomic,strong)NSMutableArray? ? *mDataArray; @property?(nonatomic,strong)UITableView?? ? ? *mtableView; @end @implementation?ViewController @end 5.2 一般变量命名? ?? ? ? ? 示例: NSMutableArray? *ticketsArray = [NSMutableArrayarrayWithCapacity:0]; ? ? NSInteger?numComplete

您可能关注的文档

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档