
Python ThreadPoolExecutor回调函数的执行线程
Python的ThreadPoolExecutor中,回调函数的执行线程并非一成不变,它取决于回调函数添加的时机:
提前添加回调:如果在提交任务(submit)之后,立即添加回调函数(add_done_callback),那么回调函数通常会在主线程执行。这是因为ThreadPoolExecutor的主线程会监控任务的完成状态,一旦任务完成,主线程就会调用已注册的回调函数。
from concurrent.futures import ThreadPoolExecutorpool = ThreadPoolExecutor()future = pool.submit(my_task)future.add_done_callback(my_callback)
延迟添加回调:如果在任务已经完成之后再添加回调函数,那么回调函数的执行线程则取决于实现细节,可能会在工作线程或主线程执行,这与具体的ThreadPoolExecutor实现和Python版本有关,没有明确的保证。 为了避免这种不确定性,建议始终在任务完成前添加回调。
立即学习“Python免费学习笔记(深入)”;
因此,为了确保回调函数在主线程执行,最佳实践是在提交任务后立即添加回调函数。 避免在任务完成后再添加回调,因为这会引入不确定性,影响代码的可预测性和可维护性。
以上就是Python ThreadPool回调函数:是在主线程还是工作线程执行?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1356979.html
微信扫一扫
支付宝扫一扫