Go 언어는 단순성과 우아함을 추구하므로 Go 언어는 전통적인 try...catch...finally 예외를 지원하지 않습니다. 왜냐하면 Go 언어 설계자는 예외를 제어 구조와 혼합하면 코드를 쉽게 혼란스럽다.
개발자는 쉽게 예외를 남용할 수 있고 심지어 작은 실수로 인해 예외를 던질 수도 있기 때문입니다. Go 언어에서는 오류를 반환하기 위해 여러 값을 사용합니다. 프로세스를 제어하는 것은 고사하고 오류를 대체하기 위해 예외를 사용하지 마십시오. 드문 경우, 즉 실제 예외가 발생하는 경우(예: 제수가 0인 경우)입니다. Go에 도입된 예외 처리(지연, 패닉, 복구)만 사용하세요.
이러한 예외의 사용 시나리오는 간단하게 설명할 수 있습니다. Go는 패닉 예외를 발생시킨 후 지연 복구를 통해 예외를 캡처한 다음 정상적으로 처리할 수 있습니다.
예방 코드 : ample
package main import "fmt" func main(){ defer func(){ // 必须要先声明defer,否则不能捕获到panic异常 fmt.Println("c") if err:=recover();err!=nil{ fmt.Println(err) // 这里的err其实就是panic传入的内容,55 } fmt.Println("d") }() f() } func f(){ fmt.Println("a") panic(55) fmt.Println("b") fmt.Println("f") }
c
55
d
exit 코드 0, 원래 영어 의미 : vi; 연기하다, 연기하다
func f() (result int) { defer func() { result++ }() return 0 }
func f() (result int) { return 0 defer func() { result++ }() return 0 }
그러나 중요한 점은 함수가 실행될 때 패닉이 발생하고 함수가 다운되지 않더라도 런타임 중에 패닉이 즉시 위로 전달되는 것이 아니라, defer에 있는 모든 일이 끝난 후에 패닉이 발생한다는 것입니다. 다시 상승했습니다. 따라서 현재 defer는 try-catch-finally의 finally와 다소 유사합니다.
패닉은 그렇게 간단합니다. 실제 예외를 발생시킵니다.recover 영어로 원래 의미: vt. 회복하다; 회복하다 n. 위에서 언급했듯이 패닉 함수는 즉시 반환하지 않고 먼저 연기한 다음 반환합니다. 이때(defer 동안) 패닉을 포착하고 패닉이 전달되는 것을 방지할 수 있는 방법이 있다면 예외 처리 메커니즘은 완성될 것입니다.
Go 언어는 복구 내장 기능을 제공합니다. 앞서 언급했듯이 패닉이 발생하면 로직이 지연되고, 복구 기능을 호출하면 현재 패닉(있는 경우)이 캡처됩니다. 공포가 위로 퍼지지 않을 것이며, 세계에 평화가 회복될 것입니다. 당신은 당신이 원하는 것을 할 수 있습니다. 그러나 복구 후에는 논리가 패닉 지점으로 돌아가지 않으며 함수는 연기 후에도 여전히 반환된다는 점에 유의해야 합니다.
결론:
위 내용은 Go 언어의 예외 처리 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!