這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
主要功能 根據 第一個 構造體變數欄位為空白的值 用第二個變數對應欄位不為空白的值 進行賦值
切記。golang 中切片類型是不可以進行對比的。
package mainimport ("fmt""reflect")type conf struct {S stringI []int}func main() {c1 := conf{S: "xiaochuan"}c2 := conf{I: []int{1, 2, 3}}v1 := reflect.ValueOf(c1) //初始化為c1保管的具體值的v1v2 := reflect.ValueOf(c2) //初始化為c2保管的具體值的v2v1_elem := reflect.ValueOf(&c1).Elem() //返回 c1 指標保管的值for i := 0; i < v1.NumField(); i++ {field := v1.Field(i) //返回結構體的第i個欄位field2 := v2.Field(i) //返回結構體的第i個欄位//field.Interface() 當前持有的值//reflect.Zero 根據類型擷取對應的 零值//這個必須調用 Interface 方法 否則為 reflect.Value 構造體的對比 而不是兩個值的對比//這個地方不要用等號去對比 因為golang 切片類型是不支援 對比的if reflect.DeepEqual(field.Interface(), reflect.Zero(field.Type()).Interface()) { //如果第一個構造體某個欄位對應類型的預設值if !reflect.DeepEqual(field2.Interface(), reflect.Zero(field2.Type()).Interface()) { //如果第二個構造體 這個欄位不為空白if v1_elem.Field(i).CanSet() != true { //如果不可以設定值 直接返回fmt.Println("not set value")return}v1_elem.Field(i).Set(field2) //設定值}}}fmt.Println(c1) //輸出最終的 c1的值}