go语言连续监控事件并回调处理

前言

go语言中使用回调函数处理事件:事件监测部分(如无限循环中的事件检测逻辑)可以独立于具体的业务处理逻辑。这使得代码的各个部分更加清晰,易于理解和维护。如果需要更改事件处理的方式,只需要修改注册的回调函数,而不需要修改事件监测的核心代码。例如,如果要改变对特定事件的响应行为,只需重新定义一个不同的回调函数并注册即可,不会影响事件监测的机制。

一、回调函数的定义

复制代码
// 定义事件处理函数类型
type EventHandler func(eventData interface{})

// 模拟事件源
type EventSource struct {
    eventHandlers []EventHandler
}

二、 添加结构体的方法

复制代码
// 注册事件处理函数
func (es *EventSource) RegisterHandler(handler EventHandler) {
    es.eventHandlers = append(es.eventHandlers, handler)
}

// 触发事件
func (es *EventSource) TriggerEvent(eventData interface{}) {
    for _, handler := range es.eventHandlers {
        handler(eventData)
    }
}

三、回调函数的实现

复制代码
// 单独定义的回调函数
func myEventHandler(data interface{}) {
    fmt.Println("Event handled by named function:", data)
}

四、事件检测

复制代码
func monitorEvents(eventSource *EventSource) {
    for {
        // 模拟检测事件,这里可以是实际的事件检测逻辑
        // 假设每2秒检测到一个事件
        time.Sleep(2 * time.Second)
        eventData := "Detected event!"
        eventSource.TriggerEvent(eventData)
    }
}

五、主函数实现

复制代码
func main() {
    eventSource := &EventSource{}

    // 注册单独定义的回调函数
    eventSource.RegisterHandler(myEventHandler)

    go monitorEvents(eventSource)

    // 让主程序持续运行,以保持监控事件的 goroutine 运行
    select {}
}
相关推荐
郭京京3 分钟前
goweb内置的 net/http 包
后端·go
dylan_QAQ4 分钟前
Java转Go全过程06-工程管理
java·后端·go
用户4099322502127 分钟前
如何用FastAPI玩转多模块测试与异步任务,让代码不再“闹脾气”?
后端·ai编程·trae
鲸屿19515 分钟前
python之socket网络编程
开发语言·网络·python
没有梦想的咸鱼185-1037-166341 分钟前
基于R语言机器学习方法在生态经济学领域中的实践技术应用
开发语言·机器学习·数据分析·r语言
考虑考虑1 小时前
Postgerssql格式化时间
数据库·后端·postgresql
Chan161 小时前
【智能协同云图库】基于统一接口架构构建多维度分析功能、结合 ECharts 可视化与权限校验实现用户 / 管理员图库统计、通过 SQL 优化与流式处理提升数据
java·spring boot·后端·sql·spring·intellij-idea·echarts
向上的车轮1 小时前
基于go语言的云原生TodoList Demo 项目,验证云原生核心特性
开发语言·云原生·golang
The Chosen One9851 小时前
C++ : AVL树-详解
开发语言·c++
PH_modest1 小时前
【Qt跬步积累】—— 初识Qt
开发语言·qt