修改部分描述,添加必要的标点符号,补充代码超链接 (#804)

This commit is contained in:
Jck
2021-10-25 23:34:42 +08:00
committed by GitHub
parent d5578df00a
commit 39dbdb7094
100 changed files with 433 additions and 414 deletions

View File

@@ -24,9 +24,9 @@ func protect(g func()) {
这跟 Java 和 .NET 这样的语言中的 catch 块类似。
log 包实现了简单的日志功能:默认的 log 对象向标准错误输出中写入并打印每条日志信息的日期和时间。除了 `Println``Printf` 函数,其它的致命性函数都会在写完日志信息后调用 os.Exit(1),那些退出函数也是如此。而 Panic 效果的函数会在写完日志信息后调用 panic可以在程序必须中止或发生了临界错误时使用它们就像当 web 服务器不能启动时那样(参见 [15.4 节](15.4.md)中的例子)。
log 包实现了简单的日志功能:默认的 log 对象向标准错误输出中写入并打印每条日志信息的日期和时间。除了 `Println``Printf` 函数,其它的致命性函数都会在写完日志信息后调用 os.Exit(1),那些退出函数也是如此。而 Panic 效果的函数会在写完日志信息后调用 panic可以在程序必须中止或发生了临界错误时使用它们就像当 web 服务器不能启动时那样(参见 [15.4 节](15.4.md) 中的例子)。
log 包用那些方法methods定义了一个 Logger 接口类型,如果你想自定义日志系统的话可以参考(参见 [http://golang.org/pkg/log/#Logger](http://golang.org/pkg/log/#Logger)
log 包用那些方法methods定义了一个 Logger 接口类型,如果你想自定义日志系统的话可以参考 [http://golang.org/pkg/log/#Logger](http://golang.org/pkg/log/#Logger)
这是一个展示 panicdefer 和 recover 怎么结合使用的完整例子:
@@ -51,7 +51,7 @@ func test() {
}
}()
badCall()
fmt.Printf("After bad call\r\n") // <-- wordt niet bereikt
fmt.Printf("After bad call\r\n") // <-- would not reach
}
func main() {
@@ -71,7 +71,7 @@ Test completed
`defer-panic-recover` 在某种意义上也是一种像 `if``for` 这样的控制流机制。
Go 标准库中许多地方都用了这个机制例如json 包中的解码和 regexp 包中的 Complie 函数。Go 库的原则是即使在包的内部使用了 panic在它的对外接口API中也必须用 recover 处理成返回显式的错误。
Go 标准库中许多地方都用了这个机制例如json 包中的解码和 regexp 包中的 Complie 函数。Go 库的原则是即使在包的内部使用了 panic在它的对外接口API中也必须用 recover 处理成显式返回的错误。
## 链接