亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Xcode中代碼注釋編寫的一些小技巧

 更新時間:2021年10月28日 09:42:25   作者:season_zhu  
如何在 Xcode 中編寫規(guī)范注釋,規(guī)范注釋可以在Xcode的快速幫助檢查器(quickheliector)中顯示,這篇文章主要給大家介紹了關(guān)于Xcode中代碼注釋編寫的一些小技巧,需要的朋友可以參考下

前言

碼農(nóng)總是在搬磚,日復(fù)一日,年復(fù)一年,有的時候都會麻木。

代碼大家都會寫,但是把注釋寫好卻是一個技術(shù)活。

下面這段話,很好的說明了寫好注釋的感覺:

注釋代碼很像清潔你的廁所——你不想干,但如果你做了,這絕對會給你和你的客人帶來更愉悅的體驗?!?Ryan Campbell

今天給大家聊的就是在Xcode中,代碼注釋編寫小技巧。

Objective-C的代碼注釋

很久很久以前,在Xcode還可以安裝插件的時代,iOSer都通過VVDocument來編寫代碼注釋的。

代碼注釋的風(fēng)格一般都是這樣的,代碼出自IQKeyboardManager/IQBarButtonItem

#import <UIKit/UIBarButtonItem.h>

@class NSInvocation;

/**
 IQBarButtonItem used for IQToolbar.
 */

@interface IQBarButtonItem : UIBarButtonItem

/**
 Boolean to know if it's a system item or custom item
 */
@property (nonatomic, readonly) BOOL isSystemItem;

/**
 Additional target & action to do get callback action. Note that setting custom target & selector doesn't affect native functionality, this is just an additional target to get a callback.

 @param target Target object.
 @param action Target Selector.
 */
-(void)setTarget:(nullable id)target action:(nullable SEL)action;

/**
 Customized Invocation to be called when button is pressed. invocation is internally created using setTarget:action: method.
 */
@property (nullable, strong, nonatomic) NSInvocation *invocation;

@end

OC的注釋是通過/** */這樣的形式進(jìn)行編寫的。

分隔符使用的是這種風(fēng)格:

#pragma mark - 這個是一個分割符

需要注意的是這個-非常的重要,通過這個-,在查看代碼的時候,可以生成分隔線,讓代碼結(jié)構(gòu)看的更為清晰。

Swift的代碼注釋

隨著Swift語言發(fā)布,在Swift中編寫注釋的風(fēng)格就所有不同了:

extension NSObject {

    /// 對象獲取類的字符串名稱
    public var className: String {
        return runtimeType.className
    }

    /// 類獲取類的字符串名稱
    public static var className: String {
        return String(describing: self)
    }

    /// NSObject對象獲取類型
    public var runtimeType: NSObject.Type {
        return type(of: self)
    }
    
    /// 這是一個例子函數(shù)
    /// - Parameter arg:
    /// - Parameter argument: 傳入Int類型的參數(shù)
    /// - Returns: 返回Int類型的參數(shù)
    public func afunction(argument: Int) -> Int {
        return argument
    }
}

Swift的注釋是通過/// 這樣的形式進(jìn)行編寫的。

分隔符使用的是這種風(fēng)格:

//MARK: - 綁定

Swift中的//MARK:這個-也是起到生成分隔線的作用。

Objective-C和Swift的注釋風(fēng)格現(xiàn)在已經(jīng)統(tǒng)一

如果你現(xiàn)在通過alt+cmd+/在OC和Swift中編寫注釋的時候,就會發(fā)現(xiàn)現(xiàn)在的注釋都變成了Swift的這個中風(fēng)格了:

我個人建議是:以前代碼注釋就讓它去吧,現(xiàn)在就都是用這個統(tǒng)一風(fēng)格。

快速修改注釋

一個函數(shù)寫好了,注釋也寫好,但是有的時候計劃沒有變化快,函數(shù)添加了新的參數(shù),這個注釋難道要手動添加?

別急,其實Xcode也為我們提供了快捷方式,我們繼續(xù)看例子,這個函數(shù)我在之前的基礎(chǔ)上添加了一個num參數(shù),但是注釋還是之前的樣子:

cmd+鼠標(biāo)左鍵點(diǎn)擊,我們可以看到左側(cè)出現(xiàn)了一個菜單,點(diǎn)擊Add Documentation

我們需要添加的參數(shù)它就來了,這樣就可以直接添加注釋了。

大家有興趣可以把菜單的選項都點(diǎn)擊試試,也許有意外的驚喜,比如Convert Function to Async,await/async。

參考文檔

VVDocumenter

總結(jié)

從VVDocument到注釋的統(tǒng)一,Xcode一直都在做改進(jìn),雖然依舊不盡人意。

但是寫好注釋,也算是碼農(nóng)的一個基本素養(yǎng)吧,大家加油修煉。

到此這篇關(guān)于Xcode中代碼注釋編寫小技巧的文章就介紹到這了,更多相關(guān)Xcode代碼注釋編寫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決ios端點(diǎn)擊按鈕閃爍問題(小tips)

    解決ios端點(diǎn)擊按鈕閃爍問題(小tips)

    這篇文章主要介紹了ios端點(diǎn)擊按鈕閃爍的解決方法(小tips),需要的朋友參考下吧
    2017-10-10
  • iOS實現(xiàn)類似微信和支付寶的密碼輸入框(UIKeyInput協(xié)議)

    iOS實現(xiàn)類似微信和支付寶的密碼輸入框(UIKeyInput協(xié)議)

    這篇文章主要介紹了iOS實現(xiàn)類似微信和支付寶的密碼輸入框,通過UIKeyInput協(xié)議為響應(yīng)者提供簡單的鍵盤輸入的功,再通過CoreGraphics繪制出密碼輸入框,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Mac Charles抓包工具詳細(xì)介紹

    Mac Charles抓包工具詳細(xì)介紹

    這篇文章主要介紹了 Mac Charles抓包工具詳細(xì)介紹的相關(guān)資料,這簡單介紹下如何安裝,使用等基礎(chǔ)知識,需要的朋友可以參考下
    2016-12-12
  • 深入分析iOS應(yīng)用中對于圖片緩存的管理和使用

    深入分析iOS應(yīng)用中對于圖片緩存的管理和使用

    這篇文章主要介紹了iOS應(yīng)用中對于圖片緩存的管理和使用,實例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-04-04
  • iOS中多網(wǎng)絡(luò)請求的線程安全詳解

    iOS中多網(wǎng)絡(luò)請求的線程安全詳解

    這篇文章主要給大家介紹了關(guān)于iOS中多網(wǎng)絡(luò)請求的線程安全的相關(guān)資料文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • iOS中對文本的字符限制示例詳解

    iOS中對文本的字符限制示例詳解

    這篇文章主要給大家介紹了關(guān)于iOS中對文本的字符限制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • iOS 仿百度外賣-首頁重力感應(yīng)的實例

    iOS 仿百度外賣-首頁重力感應(yīng)的實例

    這篇文章主要介紹了iOS 仿百度外賣-首頁重力感應(yīng)的實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • iOS中字符串換行的實現(xiàn)方法

    iOS中字符串換行的實現(xiàn)方法

    大家應(yīng)該都有所體會,單行字符數(shù)過多會影響美觀,所以下面這篇文章主要給大家介紹了關(guān)于iOS中字符串換行的實現(xiàn)方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2018-07-07
  • iOS開發(fā)之Quartz2D的介紹與使用詳解

    iOS開發(fā)之Quartz2D的介紹與使用詳解

    什么是Quartz2D?Quartz 2D是一個二維繪圖引擎,同時支持iOS和Mac系統(tǒng)。下面這篇文章主要介紹了iOS開發(fā)之Quartz2D的介紹與使用的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 實例講解iOS應(yīng)用開發(fā)中UIPickerView滾動選擇欄的用法

    實例講解iOS應(yīng)用開發(fā)中UIPickerView滾動選擇欄的用法

    這篇文章主要介紹了iOS應(yīng)用開發(fā)中UIPickerView滾動選擇欄的用法,示例代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-04-04

最新評論