작업은 두 번째 구조체의 필드가 첫 번째 구조체의 필드를 재정의하도록 동일한 유형의 두 구조체를 병합하는 것입니다. 설정되어 있는 경우. 솔루션은 값이 0일 가능성을 고려해야 합니다.
초기 접근 방식에서는 반사 사용을 고려합니다.
func merge(default *Config, file *Config) (*Config) { b := reflect.ValueOf(default).Elem() o := reflect.ValueOf(file).Elem() for i := 0; i < b.NumField(); i++ { defaultField := b.Field(i) fileField := o.Field(i) if defaultField.Interface() != reflect.Zero(fileField.Type()).Interface() { defaultField.Set(reflect.ValueOf(fileField.Interface())) } } return default }
그러나 이 접근 방식에는 문제가 있습니다. 리플렉션 사용 및 모든 경우에 0 값 확인의 어려움에 대해 설명합니다.
대체 솔루션은 인코딩/json 패키지를 활용합니다.
conf := new(Config) // New config *conf = *defConfig // Initialize with defaults err := json.NewDecoder(strings.NewReader(fileContent)).Decode(&conf) if err != nil { panic(err) }
이 접근 방식은 여러 가지 장점을 제공합니다.
주어진 기본 구성 및 파일 콘텐츠에 이 접근 방식을 사용하면 다음과 같은 출력이 생성됩니다.
&{S1: S2:file-s2 S3: S4:def S5:file-s5}
이는 다음을 보여줍니다.
위 내용은 두 번째 구조체에서 0이 아닌 값의 우선순위를 지정하여 두 개의 동일한 Go 구조체를 효율적으로 병합하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!