當某個協程出現錯誤時,通過recover捕獲panic,使得主線程中的其他協程能繼續運行
```
package main
import (
"fmt"
"time"
)
func sayHello() {
for i := 0; i < 10; i++ {
? ? ? ? time.Sleep(time.Second)
? ? ? ? fmt.Printf("hello world\\n")
? ? }
}
func test() {
defer func() {
//捕獲test拋出的panic
if err := recover(); err != nil {
? ? ? ? ? ? fmt.Println("test()發生錯誤", err)
}
? ? }()
var myMap map[int]string
? ? myMap[0] = "GOLANG"
}
func main() {
go sayHello()
go test()
for i := 0; i < 10; i++ {
? ? ? ? fmt.Println("main() ok=", i)
? ? ? ? time.Sleep(time.Second)
? ? }
}
```
- 數據類型
- 數組array
- 切片slice
- 字符串string
- map
- 結構體struct
- 方法func
- 匿名結構體(繼承)
- 字段別名
- 接口interface
- 常量
- 基礎語法
- 循環for
- 遍歷
- 函數func
- defer
- 異常處理error
- 訪問范圍
- 包
- 類型斷言
- 文件
- 打開文件
- 讀取文件
- 寫文件
- 判斷是否存在
- 拷貝文件
- JSON
- 序列化
- 反序列化
- 命令行
- 雜項
- Windows下配置加速
- 相關鏈接
- 占位符
- 隨機數rand
- 單元測試
- goroutine
- 并發和并行
- 協程和主線程
- MPG模式
- 設置CPU數量
- 全局互斥鎖
- 管道
- 示例1
- 示例2
- select
- 異常捕獲
- 反射
- 示例
- 示例-改變值
- 網絡編程
- TCP編程
- 示例一
- redis