Go에서 수많은 잠재적인 오류를 처리할 때 오류 처리가 지루해질 수 있습니다. 예를 들어 다음 코드를 고려해 보세요.
aJson, err1 := json.Marshal(a) bJson, err2 := json.Marshal(b) cJson, err3 := json.Marshal(c) dJson, err4 := json.Marshal(d) eJson, err5 := json.Marshal(e) fJson, err6 := json.Marshal(f) gJson, err4 := json.Marshal(g) if err1 != nil { return err1 } else if err2 != nil { return err2 } else if err3 != nil { return err3 } else if err4 != nil { return err4 } else if err5 != nil { return err5 } else if err5 != nil { return err5 } else if err6 != nil { return err6 }
이 코드의 오류 처리는 반복성이 높고 유지 관리가 어렵습니다. 더 깨끗하고 효율적인 접근 방식은 클로저를 사용하여 모든 오류를 한 번에 처리하는 것입니다.
var err error f := func(dest *D, src S) bool { *dest, err = json.Marshal(src) return err == nil } // EDIT: removed () f(&aJson, a) && f(&bJson, b) && f(&cJson, c) && f(&dJson, d) && f(&eJson, e) && f(&fJson, f) && f(&gJson, g) return err
이 함수 포인터 f는 오류 처리 논리를 캡슐화하고 호출을 연결하고 첫 번째 비 함수를 반환하여 기본 함수를 단순화합니다. -nil 오류가 발생했습니다. 이 기술을 구현하면 더욱 간결하고 우아한 오류 처리가 가능해집니다.
위 내용은 Go에서 여러 오류를 어떻게 적절하게 처리할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!