主頁 > 知識庫 > 淺談golang結構體偷懶初始化

淺談golang結構體偷懶初始化

熱門標簽:地圖區(qū)域圖標注后導出 官渡電銷外呼管理系統(tǒng)怎么收費 江蘇呼叫中心外呼系統(tǒng)有效果嗎 谷歌美發(fā)店地圖標注 利用地圖標注位置 杭州人工智能電銷機器人費用 貴州電話智能外呼系統(tǒng) 400開頭電話怎樣申請 赤峰電銷

運行一段程序,警告:

service/mysqlconfig.go:63::error: golang.guazi-corp.com/tools/ksql-runner/model.CreatingMysqlMongodbRecord composite literal uses unkeyed fields (vet)

其中,composite literal uses unkeyed fields這個警告找了很久原因,最終發(fā)現(xiàn)是結構體初始化的問題,自己埋雷。

例如,結構體定義如下,

type A struct {
 *B
}

使用下邊無鍵字段初始化,就會警告:

varA := A // b is of type *B

在自己看來b的類型是B*,但編譯器卻不認賬。

正確初始化方法是:

a := A{B: b}

有人說是,這只是針對"go vet"中的一個錯誤的解決方法。

因為go vet默認情況下執(zhí)行所有檢查,如果任何標志顯式設置為true,則僅運行那些測試。

相反,如果任何標志顯式設置為false,則僅禁用那些測試。

因此-printf = true運行printf檢查,-printf = false運行除printf檢查之外的所有檢查。

可以禁用這個檢查,也可以修改代碼,但是規(guī)范代碼更比較合適。

雖然這只是一個警告,有人覺得無關緊要,但是當你幾周或者幾個月后在結構體中添加了一個字段,那么你使用unkeyed初始化的所有東西都會被破壞。顯然,在一個項目中不希望遇到這種錯誤。

補充:golang中結構體的初始化方法(new方法)

準備工作:

定義結構體:Student

import (
 "fmt"
 "reflect"
)
type Student struct {
 StudentId  string `json:"sid"`
 StudentName string `json:"sname"`
 StudentClass string `json:"class"`
 StudentTeacher string `json:"class"`
}

測試代碼如下:

func main() {
 s0 := Student{}
 fmt.Println(s0)
 fmt.Println(reflect.TypeOf(s0))

 s1 := new(Student)
 fmt.Println(s1)
 fmt.Println(reflect.TypeOf(s1))

 s2 := Student{}
 fmt.Println(s2)
 fmt.Println(reflect.TypeOf(s2))

 s3 := Student{"", "", "100", "200"}
 fmt.Println(s3)
 fmt.Println(reflect.TypeOf(s3))

 s4:= Student{StudentId: "100", StudentName: "200"}
 fmt.Println(s4)
 fmt.Println(reflect.TypeOf(s4))
 
}

輸出結果:

{ }
main.Student
{ }
*main.Student
{ }
*main.Student
{ 100 200}
*main.Student
{100 200 }
*main.Student

注意:

除了s0以外,s1-s4變量全部為指向Rect結構的指針(指針變量),因為使用了new()函數(shù)和操作符

而s0的方法 s0 := Student{} 表示的是一個Student類型,兩者是不一樣的

在Go語言中,未進行初始化的變量都會被初始化為該類型的零值,例如bool類型的零值為false, int類型的零值為0, string類型的零值為空字符串. 在Go語言中沒有構造函數(shù)的概念,對象的創(chuàng)建通常交由一個全局的創(chuàng)建函數(shù)來完成,以NewXXX來命令,表示"構造函數(shù)":

func NewStudent() { 
  return Student() //返回指針
}

用 new 分配內存 內建函數(shù) new 本質上說跟其他語言中的同名函數(shù)功能一樣:new(T) 分配了零值填充的 T 類型的內存空間,并且返回其地址,一個 *T 類型的值。

務必記得 make 僅適用于 map,slice 和 channel,并且返回的不是指針。應當用 new獲得特定的指針。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • golang 實現(xiàn)兩個結構體復制字段
  • golang通過反射設置結構體變量的值
  • Golang空結構體struct{}用途,你知道嗎
  • golang修改結構體中的切片值方法
  • Golang自定義結構體轉map的操作
  • golang 結構體初始化時賦值格式介紹
  • golang gorm 結構體的表字段缺省值設置方式
  • golang 如何用反射reflect操作結構體

標簽:河池 松原 泰安 鷹潭 武漢 黔西 宜春 保定

巨人網(wǎng)絡通訊聲明:本文標題《淺談golang結構體偷懶初始化》,本文關鍵詞  淺談,golang,結構,體,偷懶,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談golang結構體偷懶初始化》相關的同類信息!
  • 本頁收集關于淺談golang結構體偷懶初始化的相關信息資訊供網(wǎng)民參考!
  • 推薦文章