iOS端项目注释规范附统一代码块

代码的注释经常被人忽略,以至于在后期维护的时候较为困难。我们准备在XX项目开始之前制定一套规范的注释体系,致力于达到就算维护人员改变也能快速上手的效果。

1.属性注释

属性注释 使用 /** 注释*/ 的文档注释格式。 这种注释相较于// 注释的优点是此属性可以在后面的引用时,在智能提示的下方显示中文注释

如果你不是在董铂然博客园看到本文请点击查看原文

例如:

/** 回复率*/
@property(nonatomic,strong)MTPoiCompareM *replyRate;
/** 回复速度*/
@property(nonatomic,strong)MTPoiCompareM *replySpeed;

在之后的调用时可以看到如下效果

并且之后在维护写完的代码时,把光标点到该属性时可以在右侧的quickhelp快速看到此属性的解释。

从实际的开发角度来看并不是所有的属性都需要添加注释,只要是属性名能从英文直译或者简单明显的属性 不需要添加属性注释

@property(nonatomic,copy)NSString *name;
@property(nonatomic,assign)float avgScore;
@property(nonatomic,assign)int dealid;
@property(nonatomic,assign)float price;
@property(nonatomic,assign)int feedbackNum;

  

①通过属性名无法快速且明显的了解该用途的属性必须添加注释,如index到底是谁的index?但是存在下列特性的属性必须添加注释

②类似于状态的标记可能有0,1,2三种情况的要将几种情况的注释一起写入

③属性名的英文直译无法说清时

上面特点与下面的代码逐条对应:

/** 顶部分类的下标*/
@property(nonatomic,assign)int index;
/** 项目类型 1是团购  2是券*/
@property(nonatomic,assign)int type;
/** 本行业平均数据*/
@property(nonatomic,copy)NSString *cateValue;

  

这里插播一下引入代码块的步骤。这里统一一属性注释的代码块为 /** <#注释#>*/  快捷键为xx

2.引入代码块的步骤

1.将橘色部分复制到项目中的任意一个位置。里面部分会自动缩成一个块如图

然后选中这些 拖入 右下角的代码块中。

拖入后松手会显示设置框,按要求设置

然后点击done, 这个代码块就会存在Xcode中。

使用代码块的好处就是可以在项目中敲出快捷键加回车就能马上出现自己预置的代码并且,按tab键可以快速切换到一个个小块进行编写

3.方法集注释

系统有一个自带的方法集注释代码块

但是这个是不带分隔线的,如果要加分隔线 还需要在后面加上 mark - 再跟上注释,有点麻烦

使用后可以达到如下效果

现统一一下,给出代码块

#pragma mark - **************** <#输入注释#>  快捷键为mark

之所以中间用****拉长是为了避免与下面的注释一起重叠在前面不易观看

所有类的数据源方法 或 代理方法的方法集前面必须加上一行方法集注释来做分隔。(代码要求将某个类的几个代理方法应该写在一起)

4.普通注释

在项目中的某个地方的逻辑可能比较复杂或者是核心思想的代码,这种地方应加上一些注释作为标注,也利于自己维护代码,利于之后别人接手代码。

例如:

现统一一下,给出代码块

// ------<#单行注释#>  快捷键为gg

5.优先级注释

这个重点注释可以自定义, 我给出我标注重点的注释的代码块如下,也建议大家可以统一,便于查看

// $$$$$ 快捷键为dd

一般写在一个大项目中经常需要跳过去修改的地方,用法是在这行代码后面快速敲上dd回车 变成这样

有时候需要找他们的时候,只需要在项目搜索里敲上就能快速定位

这里也可以设置优先级$$ 或$$$,重点或常出异常的地方都建议标注不需要吝啬。

如果你不是在董铂然博客园看到本文请点击查看原文。 转载请注明出处。

时间: 2024-11-02 17:51:05

iOS端项目注释规范附统一代码块的相关文章

IOS开发系列--Objective-C之协议、代码块、分类

概述 ObjC的语法主要基于smalltalk进行设计的,除了提供常规的面向对象特性外,还增加了很多其他特性,这一节将重点介绍ObjC中一些常用的语法特性.当然这些内容虽然和其他高级语言命名不一样,但是我们都可以在其中找到他们的影子,在文章中我也会对比其他语言进行介绍,这一节的重点内容如下: 协议protocol 代码块block 分类category 协议protocol 在ObjC中使用@protocol定义一组方法规范,实现此协议的类必须实现对应的方法.熟悉面向对象的童鞋都知道接口本身是对

IOS学习笔记--Objective-C之协议、代码块、分类

概述 ObjC 的语法主要基于smalltalk进行设计的,除了提供常规的面向对象特性外,还增加了很多其他特性,这一节将重点介绍ObjC中一些常用的语法特性.当 然这些内容虽然和其他高级语言命名不一样,但是我们都可以在其中找到他们的影子,在文章中我也会对比其他语言进行介绍,这一节的重点内容如下:(原文地址:http://www.cnblogs.com/kenshincui/p/3869639.html) 协议protocol 代码块block 分类category 协议protocol 在 Ob

iOS新建项目文件管理规范

当我们进入到新的公司的第一天,看到以前老员工编写的代码,找个东西累死人咧,那个抓耳挠腮的啊,一般情况下都有想揍人的赶脚. 哈哈,不忙,先想一下自己的代码!想一下自己写的代码怎么才能新来的人一眼就能看懂,想找什么,在几秒之内就能找到?这个就要在前期创建项目的时候留神 了, 要保证项目的易读性.易维护性以及易扩展性等. 在我看来,作为一个项目开发的领头人,你可以从两个方面着手: 项目的架构 代码的规范 今 天就先介绍我在做新项目的时候项目架构(代码规范我会在下一篇文章以总结的形式罗列出来),搞理论这

TeamTalk项目iOS端代码总结

前段时间加入一个团队,对TeamTalk进行二次开发.我负责iOS端的功能扩展.这个项目目前已经少有人维护了,iOS端在我接手后进行了一些底层改动,现在介绍给大家. TeamTalk是一个很有名气的即时通讯解决方案,github地址:https://github.com/meili/TeamTalk但是由于维护一个即时通讯项目工作量太大,内部人员分崩离析,导致项目无人维护了.iOS端最大的过时体现就是google的Protobuf库没有更新,无法使用目前最新的3.6.1版本生成的proto文件.

java代码注释规范-----转载-----http://blog.csdn.net/shiyuezhong/article/details/8205281/

1 代码注释是架起程序设计者与程序阅读者之间的通信桥梁,最大限度的提高团队开发合作效率.也是程序代码可维护性的重要环节之一.所以我们不是为写注释而写注释.下面说一下我们在诉求网二期开发中使用的代码注释规范,供大家参考下. 2 3 原则: 4 1.注释形式统一 5 6 在整个应用程序中,使用具有一致的标点和结构的样式来构造注释.如果在其它项目中发现它们的注释规范与这份文档不同,按照这份规范写代码,不要试图在既成的规范系统中引入新的规范. 7 8 2.注释内容准确简洁 9 10 内容要简单.明了.含

iOS App集成Apple Pay教程(附示例代码)

苹果在本周一发布了iOS 8.1版本,并正式开放了Apple Pay支付系统.Apple Pay是一个基于NFC的支付系统,不久将被数以万计的线下零售商店予以支持.即便这项科技并不是彻底的突破性进展,但它足以推动许多公司和零售商来支持这种支付方式,并成为苹果又一项成功的投资. Apple Pay还给开发者带来了处理支付的新渠道,用户将期望在应用中使用它,因为它将验证和交易极端简化,仅需手指轻轻一触即可完成,如果应用里面有涉及到交易,开发者很有必要集成Apple Pay.那么如何将Apple Pa

iOS统计项目的代码总行数

很多在麦子学院学习ios的学员在开班会时问老师,在ios开发的时候,不知道怎样可以统计出写了多少行代码,如何处理这个问题呢,下面跟着麦子学院的ios开发老师来探讨下. 如果要统计ios开发代码,包括头文件的,CD到项目目录下,命令如下 ① 列出每个文件的行数 复制代码 代码如下: find . -name "*.m" -or -name "*.h" -or -name "*.xib" -or -name "*.c" |xarg

js/javascript代码注释规范与示例

注释在代码编写过程中的重要性,写代码超过半年的就能深深的体会到.没有注释的代码都不是好代码.为了别人学习,同时为了自己以后对代码进行‘升级’,看看js/javascript代码注释规范与示例.来自:http://www.56.com/style/-doc-/v1/tpl/js_dev_spec/spec-comment.html 文件注释 文件注释位于文件的最前面,应包括文件的以下信息:概要说明及版本(必须)项目地址(开源组件必须)版权声明(必须)开源协议(开源组件必须)版本号(必须)修改时间(

在项目中全局添加FastClick导致图片上传插件在ios端失效的解决方案

---恢复内容开始--- 项目是移动端的项目,为了解决300ms的click延迟,所以在全局中加入了FastClick,引入的方式很简单,网上一大堆教程,这里不做赘述 我们就谈,我遇到的问题: 某天产品要我新增一个上传图片的功能,这个也不是一个很困难的需求,直接使用插件,这里我使用的是element-ui的upload插件(对于要快速的上线的东西,不必重复造轮子) 很快速也很简单的完成了需求,然后测试的时候就jj了:经测试,在安卓端是没有任何问题的,可是在ios上,始终无法打开相册和拍照,第一反