Go에서는 오류 처리가 필수입니다. 그러나 여러 오류를 처리하면 각 오류에 대한 명시적인 확인 및 처리가 필요하므로 코드가 장황해질 수 있습니다. 이 기사에서는 텍스트를 cat에 파이핑하는 인위적인 예를 검토하고 여러 오류를 효율적으로 관리하는 문제를 해결합니다.
제공된 예에는 exec.Command를 사용하여 데이터를 cat을 실행하고 출력을 읽습니다. 원본 코드의 각 줄에는 오류 처리 전용 줄이 세 개 추가되어 상당한 양의 오류 처리 코드가 생성됩니다.
우리는 코드 가독성을 저하시키지 않고 책임감 있게 오류를 처리하기 위해 노력합니다. . 다음은 관용적인 솔루션입니다.
package main import ( "fmt" "io" "io/ioutil" "os" "os/exec" ) func piping(input string) (string, error) { cmd := exec.Command("cat", "-") stdin, err := cmd.StdinPipe() if err != nil { return "", err } stdout, err := cmd.StdoutPipe() if err != nil { return "", err } err = cmd.Start() if err != nil { return "", err } _, err = io.WriteString(stdin, input) if err != nil { return "", err } err = stdin.Close() if err != nil { return "", err } all, err := ioutil.ReadAll(stdout) output := string(all) if err != nil { return output, err } return output, nil } func main() { in := "Hello world!" fmt.Println(in) out, err := piping(in) if err != nil { fmt.Println(err) os.Exit(1) } fmt.Println(out) }
이 리팩터링된 코드는 보다 간결한 방식으로 오류 처리를 활용합니다.
이러한 접근 방식을 사용하면, 불필요한 코드 중복 없이 여러 오류를 효과적으로 처리합니다. 이 기술은 적절한 오류 처리를 보장하면서 코드 가독성을 높이고 상용구를 줄입니다.
위 내용은 Go 프로그래머는 어떻게 여러 오류를 동시에 효율적으로 관리할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!