go语言回调函数的使用

前言

在 Go 语言中,回调函数是一种将一个函数作为参数传递给另一个函数,在特定的事件发生时被调用的编程模式。

一、回调函数的定义

复制代码
type OnTaskHandler func(r []byte)

type remoteTaskClient struct {
    sync.RWMutex
    onTask OnTaskHandler
}

以上定义了一个用于处理任务的结构体,可以通过设置回调函数的方式来灵活地处理不同的情况,同时使用读写锁来保证在并发环境下的安全性。

二、定义结构体方法

复制代码
func (c *remoteTaskClient) SetOnTaskHandler(onTask OnTaskHandler) {
    c.Lock()
    defer c.Unlock()
    c.onTask = onTask
}

func (c *remoteTaskClient) ProcessMessage(message []byte) {
    if c.onTask != nil {
        c.onTask(message) // 调用回调函数处理消息
    }
}

定义了两个方法一个是与回调函数绑定的方法,另一个是任务参数接收的方法。

三、主函数调用

复制代码
func main() {
    client := &remoteTaskClient{}

    // 模拟接收消息,此时没有回调函数被设置
    client.ProcessMessage([]byte("Hello, world!"))

    // 设置回调函数
    client.SetOnTaskHandler(func(data []byte) {
        fmt.Println("Received message:", string(data))
    })
    
    // 模拟接收消息,此时回调函数已被设置
    client.ProcessMessage([]byte("Hello again, world!"))
}

主函数中SetonTaskHandler方法的参数中包含了回调函数的具体实现,当接收到任务信息就会执行。

四、测试函数

复制代码
package main

import (
    "fmt"
)

type OnTaskHandler func(r []byte)

type remoteTaskClient struct {
    sync.RWMutex
    onTask OnTaskHandler
}

func (c *remoteTaskClient) SetOnTaskHandler(onTask OnTaskHandler) {
    c.Lock()
    defer c.Unlock()
    c.onTask = onTask
}

func (c *remoteTaskClient) ProcessMessage(message []byte) {
    if c.onTask != nil {
        c.onTask(message) // 调用回调函数处理消息
    }
}

func main() {
    client := &remoteTaskClient{}

    // 模拟接收消息,此时没有回调函数被设置
    client.ProcessMessage([]byte("Hello, world!"))

    // 设置回调函数
    client.SetOnTaskHandler(func(data []byte) {
        fmt.Println("Received message:", string(data))
    })
    
    // 再次模拟接收消息,此时回调函数已被设置
    client.ProcessMessage([]byte("Hello again, world!"))
}

主函数中回调函数具体通过匿名函数实现。

相关推荐
橙序员小站4 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
怒放吧德德4 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆6 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
开心就好20257 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字7 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常8 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强8 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常8 小时前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌8 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3218 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js