Swift注释命名

第一次写东西发布到网络上,还是有点小激动的。 不久之前加入了一个读书分享群。 里面很多人都说读了一定要总结出来,那样才能让自己学到的更多。于是乎,我有了写东西的冲动。 最近一直在学习Swift,现在就写写在Swift里面本人理解的注释风格。

注释:

有一个众所周知的工具 (VVDocument)

// 单行注释

/// 单行注释(三个斜杆的单行注释可以生成注释文档, 如果在开发中建议使用)

//!< 单行注释 (一般在枚举类型里面在case后面使用)

/*! 单行注释 */

/* 多行注释 */

/** 多行注释 */

///单行注释--尾行注释一般在枚举中使用
enum Test: Int {   
  web =1,//!<   web类型    
  shop =2,//!<  商铺活动  
};

文档注释

在注释里面使用**包括好的文字会粗体显示

Parameter 参数说明关键字

Throws: 抛出异常关键字

Returns: 返回对象

/// There are a few keywords Xcode can recognize automatically. The format is like **- <Keyword> -**:. The most common use one is **Parameter**, **Throws** and **Returns**.
/// **参数第一种写法**:
/// - Parameter item1: This is item1
/// - Parameter item2: This is item2
/// **参数第二种写法**
/// - Parameters:
///   - item1: This is item1
///   - item2: This is item2
/// - Throws: `MyError.BothNilError` if both item1 and item2 are nil.
/// - Returns: the result string.
func showKeywordsCommentsWithItem1(item1: AnyObject?, item2: AnyObject?) throws -> String {
    
    if item1 == nil && item2 == nil{
        throw MyError.BothNilError
    }
    
    let text = "There are a few keywords Xcode can recognize automatically."
    return text
}

/// Some meta information can be added into the comment documentation using **author**, **authors**, **copyright**, **date**, **since**, **version**
///
/// This is an example
/// - Author: xixiaoyu
/// - Authors: All the geeks in the world:)
/// - Copyright: xixiaoyu@2016
/// - Date: 2016-07-22
/// - Since: iOS 6
/// - Version: 1.0.0
func test() -> String{
    let haha = "Hello Swift"
    return haha
}

超链接

空格只是为了显示,在项目注释中不需要空格
在注释中使用[] ()中括号里面是跳转名称,小括号里面是URL, 当我们点击xxx的时候 会在默认的浏览器中打开url所指定的网页。 例如:
Whelcome to imooc.

在注释中添加显示图片! [] () 中括号里面是logo名称, 小括号里面是logo的URL。
例如:


Swift logo
Swift logo

关键字

TODO

在开发的过程中遇到一个问题的时候,有可能我们需要放哪里过会再来处理,那我们可以使用关键字 TODO来进行标记

MARK

在一个文件里面可以使用MARK来对不同的方法进行分类区分

FIXME

FIXME 标记

命名规则

使用可读的驼峰命名法去给类 方法 变量 命名。 class struct protocol enum 应使用大写,变量名使用小写。

/// 变量常量命名
let testCount = 100

/// 类命名
class TestClass { 
}

/// 结构体命名
struct TestStruct {
}

/// 枚举命名 使用首字母小写的驼峰命名法给每个case命名
enum TestEnum {
  case test1
  case test2
} 
/// 协议命名遵循Apple's API DesignGuidelines使用名词来描述, 如 ing able ible, 
protocol Prizable{
    func isPrizable() -> Bool
}

protocol Moving {
  func isMoveing() -> Bool
}

空格 空行

  • 空格:
  1. 在运算符前后空格 let p = 3 + 4
  2. 逗号后面空格。
  3. 左大括号前空格 (右大括号另起一行)
    func test(number: Int) {
    }
  4. 定义常量、变量时冒号后面空格, 冒号前面顶着常量变量。 let test: Int = 2
  5. 必包的大括号里面包含的内容需要前后空格。
    func ==(s1:Student,s2:Student) -> Bool { return s1.score == s2.score }
  • 空行:
  1. 在右大括号之后如果还有方法需要空行,如果没有则无需空行
  2. 代码块缩进原则
struct Student: CustomStringConvertible, Equatable, Comparable, Prizable {
    var name: String
    var score: Int
    var description: String{
        return name + "Score: " + String(score)
    }
    
    func isPrizable() -> Bool {
        return score >= 60
    }
}

推荐

if person.isHave {
  // Do
} else {
  // Do else
}

不推荐

if (user.isHappy ) 多余空格
{                  换行位置不对
  // Do something
}
else {
  // Do something else
}

类型定义 (转自: )

尽可能的使用swift自带类型,在必须的时候才做桥接 ,String-> NSString , Set->NSSet

能使用let尽量使用, 一般情况下不建议到处使用var

不要定义常量变量使用关键字
尽量let foo = something 而非 var for = somthing

let-有保障 并且它的值的永远不会改变,对同事也是个 清晰的标记,对于它的用法,之后的代码可以做个强而有力的推断。更容易明白代码的含义。否则的话一旦你用了 var,还要去考虑值会不会改变,这时候你就不得不人肉去检查。

这样,无论何时你看到 var,就假设它会变,并找到原因。

类型推断

Swift是高安全性语言,能让系统推断的类型不要显示指明, 空的字典和空数组的类型 使用类型标记 加强语义
如:

/// 推荐
let testString = "Hello"
var names: [String] = []
var lookup: [String: Int] = [:]
/// 不推荐
let testString: String = "Hello"

参考自

GitHub
献给写作者的 Markdown 新手指南
Swift-Code-Style

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容