GolangNote

Golang笔记

golang 回调函数的用法示例

Permalink

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

golang 回调函数

Go: 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))
}

输出

plaintext: output
1
2
3
123
Find Error: strconv.ParseInt: parsing "s": invalid syntax
0

Related articles

golang snappy 示例

snappy 是 google 开源的一种高效的压缩算法,这里是 golang 实现的 snappy 压缩示例...

bolt 使用示例

bolt 是一款高性能的key value 数据库,下面是它的使用示例:...

Golang telegram 机器人小试

telegram 的机器人接口很开放,使用简单,100%开放无限制,相对微信服务号、公众号好很多。用来做一些小应用也很方便。下面是使用golang sdk 开发telegram 机器人的经验。...

Write a Comment to "golang 回调函数的用法示例"

Submit Comment Login
Based on Golang + fastHTTP + youdb | go1.16 Processed in 1ms