Unknown 4 years ago
parent
commit
7221191c30
5 changed files with 47 additions and 5 deletions
  1. 1 1
      README.md
  2. 42 0
      eBook/06.10.md
  3. 3 0
      eBook/06.11.md
  4. 0 4
      eBook/6.10.md
  5. 1 0
      eBook/directory.md

+ 1 - 1
README.md

@@ -9,7 +9,7 @@
9 9
 
10 10
 ## 翻译进度
11 11
 
12
-6.9 [应用闭包:将函数作为返回值](eBook/06.9.md)
12
+6.10 [使用闭包调试](eBook/06.10.md)
13 13
 
14 14
 ## 支持本书
15 15
 

+ 42 - 0
eBook/06.10.md

@@ -0,0 +1,42 @@
1
+# 6.10 使用闭包调试
2
+
3
+当您在分析和调试复杂的程序时,无数个函数在不同的代码文件中相互调用,如果这时候能够准确地知道哪个文件中的具体哪个函数正在执行,对于调试是十分有帮助的。您可以使用 `runtime` 或 `log` 包中的特殊函数来实现这样的功能。包 `runtime` 中的函数 `Caller()` 提供了相应的信息,因此可以在需要的时候实现一个 `where()` 闭包函数来打印函数执行的位置:
4
+
5
+```go
6
+where := func() {
7
+	_, file, line, _ := runtime.Caller(1)
8
+	log.Printf("%s:%d", file, line)
9
+}
10
+where()
11
+// some code
12
+where()
13
+// some more code
14
+where()
15
+```
16
+
17
+您也可以设置 `log` 包中的 flag 参数来实现:
18
+
19
+```go
20
+log.SetFlags(log.Llongfile)
21
+log.Print("")
22
+```
23
+
24
+或使用一个更加简短版本的 `where` 函数:
25
+
26
+```go
27
+var where = log.Print
28
+func func1() {
29
+where()
30
+... some code
31
+where()
32
+... some code
33
+where()
34
+}
35
+```
36
+
37
+## 链接
38
+
39
+- [目录](directory.md)
40
+- 上一节:[应用闭包:将函数作为返回值](06.9.md)
41
+- 下一节:[计算函数执行时间](06.11.md)
42
+

+ 3 - 0
eBook/06.11.md

@@ -0,0 +1,3 @@
1
+# 6.11 计算函数执行时间
2
+
3
+154

+ 0 - 4
eBook/6.10.md

@@ -1,4 +0,0 @@
1
-# 6.10 使用闭包调试
2
-
3
-
4
-153

+ 1 - 0
eBook/directory.md

@@ -56,6 +56,7 @@
56 56
 	- 6.8 [闭包](06.8.md)
57 57
 	- 6.9 [应用闭包:将函数作为返回值](06.9.md)
58 58
 	- 6.10 [使用闭包调试](06.10.md)
59
+	- 6.11 [计算函数执行时间](06.11.md)
59 60
 - 第7章:数组(array)与切片(slice)
60 61
 - 第8章:Maps
61 62
 - 第9章:包(package)