当前位置: 首页 > ai >正文

回调函数应用示例

在这里插入图片描述
回调函数是一种通过函数指针(或引用)调用的函数,它在特定事件或条件发生时被另一个函数调用。回调函数的核心思想是将函数作为参数传递,以便在适当的时候执行自定义逻辑,常用于异步编程、事件驱动架构等场景。


业务场景及示例

1. 事件处理(如GUI按钮点击)

在图形界面中,用户点击按钮后触发特定操作。

# 示例:模拟事件处理器
class Button:def __init__(self):self.click_handlers = []  # 保存回调函数的列表def add_click_handler(self, handler):self.click_handlers.append(handler)def click(self):print("按钮被点击了!")for handler in self.click_handlers:handler()  # 执行所有注册的回调函数# 定义回调函数
def show_message():print("弹出提示:操作成功!")# 使用
button = Button()
button.add_click_handler(show_message)
button.add_click_handler(lambda: print("记录日志:按钮点击事件"))  # 使用Lambda表达式
button.click()# 输出:
# 按钮被点击了!
# 弹出提示:操作成功!
# 记录日志:按钮点击事件

2. 异步任务完成后的处理

例如,下载文件完成后自动处理数据。

import time
import threading# 模拟异步下载
def download_file(url, callback):def download_task():print(f"开始下载 {url}...")time.sleep(2)  # 模拟耗时操作data = f"下载内容:{url}"callback(data)  # 下载完成后调用回调处理数据threading.Thread(target=download_task).start()  # 启动新线程# 定义回调函数:处理下载结果
def process_data(data):print(f"处理数据: {data}")# 使用
download_file("https://example.com/data.csv", process_data)
print("下载进行中,主线程继续运行...")  # 非阻塞# 输出:
# 开始下载 https://example.com/data.csv...
# 下载进行中,主线程继续运行...
# (2秒后)处理数据: 下载内容:https://example.com/data.csv

3. 定时任务调度

在指定时间后执行回调(如定时提醒)。

import time
from threading import Timer# 定义定时器回调
def schedule_task(delay, callback):def task():time.sleep(delay)callback()Timer(0, task).start()  # 启动定时线程# 回调函数:定时任务内容
def remind():print("提醒:会议将在5分钟后开始!")# 使用
schedule_task(10, remind)  # 10秒后触发提醒
print("定时器已设置,主线程继续工作...")# 输出:
# 定时器已设置,主线程继续工作...
# (10秒后)提醒:会议将在5分钟后开始!

回调函数的优势

  1. 解耦逻辑:将触发逻辑与处理逻辑分离。
  2. 灵活性:允许动态扩展功能(如插件系统)。
  3. 异步支持:适用于I/O密集型任务(如网络请求)。

注意事项

过度使用回调可能导致“回调地狱”(嵌套层次深),此时可改用 Promiseasync/await(Python 的 asyncio)。

http://www.xdnf.cn/news/6494.html

相关文章:

  • 网络安全-等级保护(等保) 2-5-1 GB/T 25070—2019 附录B (资料性附录)第三级系统安全保护环境设计示例
  • IEC 60601-2-16:2025 标准解析
  • python打卡day27
  • TCP/IP 知识体系
  • 国标GB/T 12536-90滑行试验全解析:纯电动轻卡行驶阻力模型参数精准标定
  • 【AI大模型学习路线】第二阶段之RAG基础与架构——第七章(【项目实战】基于RAG的PDF文档助手)query搜索与文档排序?
  • win10-django项目与mysql的基本增删改查
  • 从代码学习深度学习 - 实战Kaggle比赛:狗的品种识别(ImageNet Dogs)PyTorch版
  • 关于nginx浏览器访问.php直接被当做文件下载相关问题
  • Github 2025-05-16 Java开源项目日报 Top9
  • OM和SCADA的区别
  • 目标检测指标计算
  • C++ I/O多路复用
  • uniapp自定义日历计划写法(vue2)
  • 生信分析进阶15 - 从GTF文件提取起始密码子、终止密码子、外显子剪切供体和受体
  • 基于大模型的脑出血智能诊疗与康复技术方案
  • 计算机组成原理——数据的表示
  • 使用 Docker 部署 React + Nginx 应用教程
  • 4.2.3 Thymeleaf标准表达式 - 5. 片段表达式
  • mac M芯片运行docker-desktop异常问题
  • 保姆教程-----安装MySQL全过程
  • minio存储文件迁移磁盘
  • SpringBoot + Shiro + JWT 实现认证与授权完整方案实现
  • 《k-means 散点图可视化》实验报告
  • 在服务器上安装AlphaFold2遇到的问题(3)_cat: /usr/include/cudnn_version.h: 没有那个文件或目录
  • 从概念到可工程化智能体的转变路径——以“知识奇点工程师”为例
  • Secs/Gem第四讲(基于secs4net项目的ChatGpt介绍)
  • Python零基础入门到高手8.4节: 元组与列表的区别
  • 深度学习中--模型调试与可视化
  • 易境通海外仓WMS系统:赋能海外仓多元化业务场景管理