Go에서 지역 변수를 사용한 패닉 복구가 작동하지 않는 이유는 무엇입니까?
Go에서는 오류 처리를 위해 패닉 및 복구를 사용하는 것이 일반적입니다. . 그러나 패닉 복구에서 반환 값으로 로컬 변수를 사용할 때 동작에는 미묘한 차이가 있습니다.
다음 코드를 고려하세요.
<code class="go">func main() { result, err := foo() fmt.Println("result:", result) if err != nil { fmt.Println("err:", err) } } func foo() (result int, err error) { defer func() { if e := recover(); e != nil { result = -1 err = errors.New(e.(string)) } }() bar() result = 100 err = nil return } func bar() { panic("panic happened") }</code>
bar()에서 패닉이 발생하면 복구( ) Deferred closure의 함수가 실행됩니다. 결과에 -1을 할당하고 오류 개체를 생성합니다. 이 코드의 출력은 정확합니다.
result: -1 err: panic happened
그러나 반환 값에 지역 변수를 사용하는 경우:
<code class="go">func main() { result, err := foo() fmt.Println("result:", result) if err != nil { fmt.Println("err:", err) } } func foo() (int, error) { var result int var err error defer func() { if e := recover(); e != nil { result = -1 err = errors.New(e.(string)) } }() bar() result = 100 err = nil return result, err } func bar() { panic("panic happened") }</code>
이 경우 출력은 다릅니다.
result: 0
recover() 함수가 지역 변수 'result'에 -1을 할당하기 때문입니다. 그러나 함수는 명명된 반환 값 결과(0으로 초기화됨)를 반환하므로 지역 변수 할당은 효과가 없습니다.
이 동작의 이유는 Go 둘러보기 기본 사항에 있습니다.
"이름이 지정된 반환 값은...함수 상단에 정의된 변수로 처리됩니다."
이름이 지정된 반환 값을 사용하는 경우 지연 클로저 내부의 변경 사항이 반환 값에 반영됩니다. 하지만 로컬 변수를 사용하는 경우 변경 사항은 반환된 값이 아닌 로컬 범위에만 반영됩니다.
위 내용은 지역 변수를 사용한 패닉 복구가 Go에서 반환 값을 변경하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!