目录:

一、格式化代码

二、命名

命名要求

1. 类的命名:

规则:

大驼峰命名法,每个单词的首字母都采用大写字母。一般添加业务前缀。后缀一般是当前类的种类。

ViewController:后缀:ViewController

NavigationController:后缀:ViewController

TabBarController:后缀:TabBarController

View:        后缀:View

Model:      后缀:

Cell:          后缀:Cell

Delegate:  后缀:Delegate

......

方法:

前缀+业务名称(或继承关系名称)+类别名称

示例:

XSDBaseNavigationController

XSDHomePageViewController

AccountCouponCell

2. 私有变量:

规则:

小驼峰命名法,第一个单词以小写字母开始,后面的单词的首字母全部大写。

方法:

在 .m 文件中声明私有变量,以 ”_“ 开头。

示例:

3. @property 变量:

规则:

小驼峰命名法。

方法:

@property (nonatomic, copy) NSString *dateCreated;//消息创建时间

示例:

4. 宏命名:

规则:

1>全部大写,以 ”_“连接[不带参数];

2>以字母 ”k“ ,后面遵循大驼峰命名[不带参数];

3>小驼峰命名[可带参数]。

方法:

示例:

#define MWPHOTO_PROGRESS_NOTIFICATION @"MWPHOTO_PROGRESS_NOTIFICATION"

#define kScreenHeight [UIScreen mainScreen].bounds.size.height      //获取设备的物理高度

#define getImageUrl(url) [NSURL URLWithString:[NSString stringWithFormat:@"%@%@",kBaseUrl,url]]

5. 枚举定义:

规则:

Enum类型的命名与类的命名规则一致。

Enum中枚举内容的命名需要以该Enum类型名称开头。

方法:

示例:

6. Delegate:

规则:

类的实例必须为回调方法的参数之一。

回调方法的参数只有类自己的情况,方法名要符合实际含义

以类的名字开头(回调方法存在两个以上参数的情况)以表明此方法是属于哪个类的。

使用did和will通知Delegate已经发生的变化或将要发生的变化。

方法:

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

- (NSInteger)numberOfSectionsInTableView:(UITableView*)tableView

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

- (NSIndexPath*)tableView:(UITableView*)tableView willSelectRowAtIndexPath:(NSIndexPath*)indexPath;

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

示例:

7.

规则:

大驼峰命名法,一般添加业务前缀。

方法:

示例:

三、注释

注释要求

1. 属性变量注释:

规则:

在定义的属性变量后添加注释。

方法:

使用”//“ + 说明

示例:

@property (nonatomic, copy) NSString * overdueSum;      //已逾期总额

2. 方法注释:

规则:

在方法声明的 .h 文件中,添加方法作用、各个参数及返回结果的说明

方法:

在声明时添加如下图的注释。

在实现文件 .m 中添加 #pragma mark - 功能

示例:

.h 文件中如下:

在 .m 文件中:

#pragma mark - 获取账户中心优惠券

3. 类的注释:

规则:

在类的头文件中添加注释,声明当前类的描述。

方法:

在 .h 文件中添加 Class 描述+功能

示例:

四、Cocoa 和 Objective-C特有的规则

五、Cocoa Pattern

六、其他

项目管理之 Objective-C 编码规范的更多相关文章

  1. JavaEE程序编码规范

    JavaEE程序编码规范 目   录 JAVA程序编码规范1 1变量的命名规则1 1.1常量(包含静态的)1 1.2类变量(静态变量)及实例变量1 1.3局部变量1 1.4参数2 1.5其它2 2方法 ...

  2. 初级c++编码规范

        想了很久,第一篇文章还是应该写编码规范好一点.编码规范是一个仁者见仁的问题,为了避免复杂庞大,自己总结了一套简单版本的规范. 简介     本文介绍一份自己使用的C++编码规范.第一次正式进入 ...

  3. Android的编码规范

    一.Android编码规范 1.学会使用string.xml文件 在我看来,当一个文本信息出现的次数大于一次的时候就必须要使用string.xml 比如一个保存按钮 , 不规范写法: <Butt ...

  4. PHP 高级编程(1/5) - 编码规范及文档编写

    PHP 高级程序设计学习笔记20140612 软件开发中的一个重要环节就是文档编写.他可以帮助未来的程序维护人员和使用者理解你在开发时的思路.也便于日后重新查看代码时不至于无从下手.文档还有一个重要的 ...

  5. 【原】JAVA SE编码规范

    /* * 编码规范: * 1.所有的命名遵循"见名知意"的原则 * 2.所有的命名不允许使用汉字或拼音 * 3.Java的工程命名建议使用小写,比如:oa.crm.cms... * ...

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

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

  7. PHP编码规范PSR-2

    .note-content { font-family: "Helvetica Neue", Arial, "Hiragino Sans GB", STHeit ...

  8. Objective-C开发编码规范【转载】

    概要 Objective-C是一门面向对象的动态编程语言,主要用于编写iOS和Mac应用程序.关于Objective-C的编码规范,苹果和谷歌都已经有很好的总结: Apple Coding Guide ...

  9. 前端编码规范之CSS

    "字是门面书是屋",我们不会去手写代码,但是敲出来的代码要好看.有条理,这还必须得有一点约束~ 团队开发中,每个人的编码风格都不尽相同,有时候可能存在很大的差异,为了便于压缩组件对 ...

  10. 前端编码规范之JavaScript

    上次浅谈了下关于CSS的编码规范,大部分童鞋持赞同意见,仍存在一些童鞋不太理解这些规范的意义. 如果是个人或者小作坊开发,其实这些所谓的编码规范也没啥意思,因为大家写好的代码直接就给扔到网上去了,很少 ...

随机推荐

  1. java nio(一)buffer

    概述 常见的网络io分为两种情况,BIO(block-io)和NIO(non-block-io),分别位于java.io和java.nio. BIO,是阻塞的io,采用一个线程处理一个连接的方式,就算 ...

  2. jQuery / zepto ajax 全局默认设置

    jQuery / zepto 的 $.ajax 方法需要配置很多选项, 有些是很常用的每个 ajax 请求都要用到的, 可以全局设置, 避免每次都写. 注意: 此处用的 jQuery 版本是 1.8. ...

  3. 篇4 安卓app自动化测试-Appium API进阶

    篇4                 安卓app自动化测试-Appium API进阶 --lamecho辣么丑 1.1概要 大家好! 我是lamecho(辣么丑),今天是<安卓app自动化测试& ...

  4. CSS3 & SVG 制作钟表

    在线演示      源码下载

  5. ZJOI2017 day1滚粗记

    这几天去温州作为外省选手参加了$ZJOI day1$.打了几天的酱油,考试也滚粗了.. $day -2$ 中午从学校出发,坐飞机去温州.到了温州以后吃完晚饭就回宾馆.把一直想做的糖果公园做完了以后就堕 ...

  6. xmlplus 组件设计系列之八 - 分隔框(DividedBox)

    分隔框(DividedBox)是一种布局类组件,可以分为两类,其中一类叫水平分隔框(HDividedBox),另一类叫垂直分隔框(VDividedBox).水平分隔框会将其子级分为两列,而垂直分隔框则 ...

  7. 蓝桥杯-分小组-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  8. Xmind 体验分享

    Xmind 8 体验 初识思维脑图 这两天在学习使用思维脑图(xmind是其中一款软件)ing,在体验了一把思维脑图的使用后,深深感受到了脑洞大开的魔力. 从昨晚开始研究使用,到今天晚上截止,自己试着 ...

  9. vector作为参数的三种传参方式

    c++中常用的vector容器作为参数时,有三种传参方式,分别如下(为说明问题,用二维vector): function1(std::vector<std::vector<int> ...

  10. [刷题]算法竞赛入门经典(第2版) 4-3/UVa220 - Othello

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa 220 - Othello #include<iostream ...