下面是一个简单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 转摘请注明来源