0

0

如何正确向 threading.Timer 的回调函数传递参数

花韻仙語

花韻仙語

发布时间:2026-02-07 10:44:27

|

456人浏览过

|

来源于php中文网

原创

如何正确向 threading.Timer 的回调函数传递参数

当使用 python 的 threading.timer 定时执行函数时,若目标函数需要接收参数(如 `warntime(i)`),必须通过 `args` 或 `kwargs` 显式传入;直接写 `timer(20, warntime)` 会导致 typeerror,因 timer 默认不提供任何参数。

在多线程定时任务中,threading.Timer 是一个常用工具,用于延迟执行某个函数。但它的构造签名是:

Timer(interval, function, args=None, kwargs=None)

其中:

  • interval:延迟秒数(float);
  • function:函数对象本身(不带括号,未调用);
  • args:元组或列表,用于按位置传参(如 (0,) 或 [0]);
  • kwargs:字典,用于按关键字传参(如 {'i': 0})。

你原始代码的问题在于:

t = Timer(20, warnTime)  # ❌ 错误:warnTime 被期待接收参数 i,但 Timer 没给

此时 Timer 在 20 秒后调用 warnTime()(无参数),而函数定义为 def warnTime(i):,因此抛出 TypeError: warnTime() missing 1 required positional argument: 'i'。

✅ 正确做法是显式传入参数:

Postme
Postme

Postme是一款强大的AI写作工具,可以帮助您快速生成高质量、原创的外贸营销文案,助您征服全球市场。

下载
from threading import Timer

def warnTime(i):
    i += 1
    print(f"Warning time reached: i = {i}")

# ✅ 传入初始值 0 作为位置参数
t = Timer(20, warnTime, args=[0])
t.start()
? 提示:args 接受序列类型(推荐 list 或 tuple),单个参数时务必写成 [0] 或 (0,),而非 args=0(会报错)。

如需传多个参数,例如 def warnTime(i, msg),可写为:

t = Timer(20, warnTime, args=[5, "Overdue!"])

或使用关键字参数(更清晰、可读性更强):

def warnTime(i=0, msg="Alert"):
    i += 1
    print(f"{msg}: i = {i}")

t = Timer(20, warnTime, kwargs={"i": 0, "msg": "Timeout"})

⚠️ 注意事项:

  • Timer 只执行一次;如需周期性执行,请自行在函数内递归启动新 Timer,或改用 threading.Thread + time.sleep() 循环;
  • 若函数中修改的是不可变对象(如 int, str),参数传递为值传递,原变量不会被外部影响(本例中 i += 1 仅作用于函数局部);
  • 确保 args/kwargs 中的数据在线程执行时仍有效(避免引用已销毁的对象)。

总结:向 Timer 回调函数传参不是“调用函数”,而是配置其未来调用的方式——关键在于正确使用 args 或 kwargs 参数,而非在构造时加括号调用函数。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

581

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

104

2025.10.23

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

606

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

551

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

173

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

204

2025.08.29

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

612

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

282

2025.12.24

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号