golang出现panic是什么原因

(*-*)浩
풀어 주다: 2019-12-28 09:24:57
원래의
4569명이 탐색했습니다.

golang出现panic是什么原因

在go中,当程序出现异常时,会发生panic。当发生panic后,需要使用recover捕获,如果没有捕获,则程序退出。

panic用来表示异常,即不该出现的错误或者意料不到的错误。(推荐学习:go

package main import "fmt" import "runtime/debug" func fun() { fmt.Println("fun begin") defer func() { //捕获panic if err := recover(); err != nil { debug.PrintStack() //获取堆栈信息的字符串 fmt.Println("xxx", string(debug.Stack())) } }() var p *int //产生异常 *p = 0 fmt.Println("fun end") //这里不执行 for {} } func main() { fmt.Println("main begin") fun() //因为panic被recover捕获,所以下面继续执行 fmt.Println("main end") for {} }
로그인 후 복사

输出结果:

main begin fun begin goroutine 1 [running]: runtime/debug.Stack(0xc000088060, 0xc00009a000, 0xa) /usr/local/Cellar/go/1.11.1/libexec/src/runtime/debug/stack.go:24 +0xa7 runtime/debug.PrintStack() /usr/local/Cellar/go/1.11.1/libexec/src/runtime/debug/stack.go:16 +0x22 main.fun.func1() /Users/xxx/test/a.go:10 +0x46 panic(0x10a9760, 0x115d520) /usr/local/Cellar/go/1.11.1/libexec/src/runtime/panic.go:513 +0x1b9 main.fun() /Users/xxx/test/a.go:16 +0x7f main.main() /Users/xxx/test/a.go:24 +0x66 xxx goroutine 1 [running]: runtime/debug.Stack(0xc00007ada8, 0x10a9760, 0x115d520) /usr/local/Cellar/go/1.11.1/libexec/src/runtime/debug/stack.go:24 +0xa7 main.fun.func1() /Users/xxx/test/a.go:11 +0x4b panic(0x10a9760, 0x115d520) /usr/local/Cellar/go/1.11.1/libexec/src/runtime/panic.go:513 +0x1b9 main.fun() /Users/xxx/test/a.go:16 +0x7f main.main() /Users/xxx/test/a.go:24 +0x66 main end
로그인 후 복사

위 내용은 golang出现panic是什么原因의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!