好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Go語言學習技巧之命名規范

Go語言學習技巧之命名規范

熱門標簽:阿里云ai電話機器人 濱州自動電銷機器人排名 鄭州亮點科技用的什么外呼系統 汕頭小型外呼系統 浙江高頻外呼系統多少錢一個月 建造者2地圖標注 黃岡人工智能電銷機器人哪個好 惠州電銷防封電話卡 釘釘有地圖標注功能嗎

前言

本篇主要講述Go語言的命名規范。優秀的代碼必須具備良好的可讀性,而可讀性的關鍵即在于命名風格。

Go的函數、變量、常量、自定義類型、包(Package)的命名方式遵循以下規則:

      1)首字符可以是任意的Unicode字符或者下劃線

      2)剩余字符可以是Unicode字符、下劃線、數字

      3)字符長度不限

Go只有25個關鍵字

break default func interface select
case defer go map struct
chan else goto package switch
const fallthrough if range type
continue for import return var

優秀的命名

  • 優秀的命名應當是一貫的、短小的、精確的。
  • 所謂一貫,就是說同一個意義在不同的環境下的命名應當一致,譬如依賴關系,不要在一個方法中命名為depend,另一個方法中命名為rely。
  • 所謂短小,不必多言,當命名過長的時候,讀者可能更關注命名本身,而忽視真正的邏輯內容。
  • 所謂精確,就是命名達意、易于理解

首條經驗

聲明位置與使用位置越遠,則命名應當越長。

駱駝命名法

  • Go語言應該使用 MixedCase
  • (不要使用 names_with_underscores)
  • 首字母縮寫詞都應該用大寫,譬如ServeHTTP、sceneID、CIDRProcessor。

局部變量

  • 局部變量應當盡可能短小,譬如使用buf指代buffer,使用i指代index
  • 在很長的函數中可能會有很多的變量,這個時候可以適當使用一些長名字。
  • 但是寫出這么長的函數,通常意味著代碼需要重構了!🙅🏻‍

參數

函數的參數和局部變量類似,但是它們默認還具有文檔的功能

當參數類型具有描述性的時候,參數名就應該盡可能短小:

func AfterFunc(d Duration, f func()) *Timer
func Escape(w io.Writer, s []byte)

當參數類型比較模糊的時候,參數名就應當具有文檔的功能:

func Unix(sec, nsec int64) Time
func HasPrefix(s, prefix []byte) bool

返回值

在Go語言中,返回值可以定義名稱的,它可以當做一種特殊的參數。

尤其重要的是,在外部可見的函數中,返回值的名稱應當可以作為文檔參考。

func Copy(dst Writer, src Reader) (written int64, err error)
func ScanBytes(data []byte, atEOF bool) (advance int, token []byte,
 err error)

方法接收者(Receiver)

方法接收者也是一種特殊的參數。Go語言中沒有明顯的面向對象的概念,可以對方法定義方法接收者來實現類似于對象的方法的概念。

按照慣例,由于方法接收者在函數內部經常出現,因此它經常采用一兩個字母來標識方法接收者的類型。

func (b *Buffer) Read(p []byte) (n int, err error)
func (sh serverHandler) ServeHTTP(rw ResponseWriter, req *Request)
func (r Rectangle) Size() Point

需要注意的是,方法接收者的名字在同一類型的不同方法中應該保持統一,這也是前文所述的一貫性的需求。

導出包級別命名

導出名被使用的時候通常是放在包名后

所以,在導出變量、常數、函數和類型的時候,

不要把包名的意義再寫一遍

比較好的名字

bytes.Buffer strings.Reader

比較蠢的名字

bytes.ByteBuffer strings.StringReader

接口類型

只含有一個方法的接口類型通常以函數名加上er后綴作為名字

type Reader interface {
  Read(p []byte) (n int, err error)
}

有時候可能導致蹩腳的英文,但別管他,能看懂就好

type Execer interface {
  Exec(p []byte) (n int, err error)
}

有時候可以適當調整一下英文單詞的順序,增加可讀性:

type ByteReader interface {
  ReadByte(p []byte) (n int, err error)
}

當接口含有多個方法的時候,還是要選取一個能夠精準描述接口目的的名字,譬如net.Conn、http/ResponseWriter

Error的命名

Error類型應該寫成FooError的形式

type ExitError struct {
 ....
}

Error變量協程ErrFoo的形式

var ErrFormat = errors.New("unknown format")

包的命名

應當與它導出代碼的內容相關,避免util、common這種寬泛的命名

引入路徑

包路徑的最后一個單詞應該和包名一致

包路徑應該盡可能簡潔

記得把庫的主要代碼直接放在代碼庫的根目錄

避免在包路徑中使用任何大寫字母(并非所有文件系統都區分大小寫)

標準庫

上述很多例子都是從標準庫中來的

標準庫的很多內容都可以作為參考
多看看標準庫來尋求靈感吧

但是要記住:

當作者寫標準庫的時候,他們自己也在學習過程中。
多數情況下作者是對的,但是偶爾還是會犯一些錯誤

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

參考文獻

What's in a name? - Andrew Gerrand

您可能感興趣的文章:
  • 詳解Golang 推薦的命名規范

標簽:東營 泰安 駐馬店 滄州 阿壩 瀘州 晉中 昭通

巨人網絡通訊聲明:本文標題《Go語言學習技巧之命名規范》,本文關鍵詞  語言學習,技巧,之,命名,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Go語言學習技巧之命名規范》相關的同類信息!
  • 本頁收集關于Go語言學習技巧之命名規范的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产熟女大XXXSm免费| 一二三四在线播放视频国语版| 国精产品一线二线三线影院| 免费看男女又大又粗又硬| 亚洲国产天堂在线mv网站| 亲子乱高潮1000部| 男女做爰猛烈床视频免费| bdsm日本折磨tv| 18人口工彩画大全第一版| 欲奴在线播放| 欧美日韩高清一区二区三区| 国产精品一级毛片久久久网曝门| 处破除破苞一区二区三区免费视频| 乱H高H继NP| 91丨精品丨蝌蚪丨白丝jk| 女男秘?看片黄全部免费| 双性受自慰夹腿磨桌角道| 男男扒开双腿疯狂进出| cd 直男 服务| 男人cao女人视频在线观看| 师生yin乱专辑| 好想被狂躁a片视频免费| 可以免费看b站剧的软件| 免费看做 爰60分钟视频| 日韩一级片在线免费观看| 色婷婷国产| 同桌乖~腿打开一点我轻一点| 国产午夜精品久久久久免费视小说 | 家庭伦乱视频| 日产MV和欧美MV的区别| 日本BBW?BBW| 为爱iGAO激情在线视频女女| 轻点呻吟耸动炕上被窝| 欧美—级v免费大片| 欧美乱妇无码aⅴ毛片欲仙欲 | 雷电将军大战史莱姆下载地址| 日本高清免费zzzzzzzz| 欧美成人www在线观看网页| 强肉乱公妇| 久久精品国产一边亲一边做| 国产伦精品一区二区三区免费舒淇|