下面是一个简单golang 回调函数的用法示例,输出自己定义的log。

golang 回调函数

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 转摘请注明来源