Go language pursues simplicity and elegance, so Go language does not support the traditional try...catch...finally exception, because the designers of Go language believe that, Mixing exceptions with control structures can easily clutter your code. Because developers can easily abuse exceptions and even throw an exception for a small error.
In Go language, use multi-value return to return errors. Don't use exceptions to replace errors, let alone control the process. In rare cases, that is, when a real exception is encountered (such as the divisor is 0). Only use the Exception handling introduced in Go: defer, panic, recover.
The usage scenarios of these exceptions can be described simply: Go can throw a panic exception, then capture the exception through recover in defer, and then handle it normally.
Example code:
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") } 输出结果: a c d exit code 0, process exited normally.
defer
##defer Original English meaning: vi. To postpone; to postpone; to obey vt. To postpone ; To postpone. The idea of defer is similar to the destructor in C, but in the Go language, what is "destructed" is not the object, but the function. Defer is used to add statements that are executed when the function ends. Note that the emphasis here is on adding, not specifying, because unlike the destructor in C which is static, the defer in Go is dynamic.func f() (result int) { defer func() { result++ }() return 0 }
panic
panic is used to indicate a very serious and unrecoverable error. In the Go language, this is a built-in function that receives a value of type interface{} (that is, any value) as a parameter. The function of panic is just like the exceptions we usually come into contact with. However, Go does not have try...catch, so panic will generally cause the program to hang (unless it is recovered). Therefore, exceptions in the Go language are really exceptions. You can try calling panic to see if the program hangs immediately, and then the call stack will be printed out when Go is running. However, the key point is that even if the function panics when it is executed, the function does not go down. The panic is not immediately transferred upward during runtime, but to defer, and everything in defer is finished. , the panic is passed upward again. So at this time defer is a bit similar to finally in try-catch-finally.recover
#As mentioned above, the panic function does not return immediately, but defers first and then returns. At this time (during defer), if there is a way to capture the panic and prevent the panic from being delivered, then the exception handling mechanism will be perfect. Go language provides the recover built-in function. As mentioned earlier, once panic occurs, the logic will go to defer, then we will wait at defer. Calling the recover function will capture the current panic (if If so), the captured panic will not be passed upwards, and peace will be restored to the world. You can do what you want. However, it should be noted that after recovery, the logic will not be restored to the panic point, and the function will still return after defer. For more go language knowledge, please pay attention to thego language tutorial column on the PHP Chinese website.
The above is the detailed content of Introduction to exception handling methods in Go language. For more information, please follow other related articles on the PHP Chinese website!