panic和recover
===
### Panic
- 用户不可恢复的错误
- panic 推出前会执行defer指定的内容
~~~
func division(a,b int) int {
if b == 0 {
panic("b = 0")
}
c := int(a / b)
return c
}
func TestDivision(t *testing.T) {
i := division(1, 0)
fmt.Println(i)
}
~~~
### recover 用户错误恢复
```
defer func() {
if err != recover();err!=nil{
// 恢复代码
}
}
```
~~~
func division(a,b int) int {
if b == 0 {
panic("b = 0")
}
c := int(a / b)
return c
}
func TestDivision(t *testing.T) {
defer func() {
if err := recover();err != nil {
fmt.Println(err)
}
}()
i := division(1, 0)
fmt.Println(i)
}
~~~
注意:如果没有处理好,就会形成僵尸服务进程
- Hello World
- UDP
- UDP服务端
- UDP客户端
- UDP广播
- 错误处理
- 编写好的异常处理
- panic和recover
- 并发编程
- Hello Goruntine
- 共享内存并发机制
- RWMutex
- CSP并发机制
- 多路复用和超时控制
- 通道关闭与广播
- Context与任务的取消
- 只运行一次
- 按需任意任务完成
- 所有任务完成
- 补充:range channel注意实现
- 对象池
- sync.Pool临时对象池
- 单元测试
- 表格测试法
- Banchmark
- BDD
- 反射
- 利用反射编写灵活的代码
- Struct Tag
- 万能程序
- 常用架构模式
- Pipe-filter pattern
- Micro Kernel
- 性能分析
- 高性能代码
- sync.MAP分析
- Concurrent Map
- GC友好的代码
- Uber开发风格规范