下面是一个简单golang 回调函数的用法示例,输出自己定义的log。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package main
import (
"fmt"
"strconv"
)
//一个记录日志的类型:func(string)
type saveLog func(msg string)
//将字符串转换为int64,如果转换失败调用saveLog
func stringToInt(s string, log saveLog) int64 {
if value, err := strconv.ParseInt(s, 0, 0); err != nil {
log(err.Error())
return 0
} else {
return value
}
}
//记录日志消息的具体实现
func myLog(msg string) {
fmt.Println("Find Error:", msg)
}
func main() {
fmt.Println(stringToInt("123", myLog)) //转换时将调用mylog记录日志
fmt.Println(stringToInt("s", myLog))
}
输出
1
2
3
123
Find Error: strconv.ParseInt: parsing "s": invalid syntax
0
本文网址: https://golangnote.com/topic/7.html 转摘请注明来源