Python:使用守护程序线程在一段时间后终止多线程程序

时间:2015-04-26 04:43:15

标签: python multithreading daemon python-daemon

我想实现一个程序,该程序将在运行一段时间t后终止,并使用t从命令行读取ArgumentParser。目前我有以下代码(省略一些细节):

def run():
    parser = create_arg_parser()
    args = parser.parse_args()
    class_instance = MultiThreadClass(args.arg1, args.arg2)
    class_instance.run()

if __name__ == '__main__':
    run_thread = Thread(target=run)
    run_thread.daemon = True
    run_thread.start()
    time.sleep(3.0)

该程序按预期工作(在运行3秒后终止)。但正如我之前提到的,运行时间(上面的代码片段中的3.0)应该从命令行输入(例如args.arg3 = 3.0)而不是硬编码。显然我不能直接放time.sleep(args.arg3)。我想知道是否有任何方法可以解决我的问题?不使用守护程序线程的答案也欢迎!感谢。

PS。如果我将参数解析代码放在run函数之外,如:

def run(args):
    class_instance = MultiThreadClass(args.arg1, args.arg2)
    class_instance.run()

if __name__ == '__main__':
    parser = create_arg_parser()
    args = parser.parse_args()
    run_thread = Thread(target=run(args))
    run_thread.daemon = True
    run_thread.start()
    time.sleep(args.arg3)

程序不会在args.arg3秒后终止,我对原因感到困惑。如果有人能解释所有这些背后的魔力,我也非常感激......非常感谢!

1 个答案:

答案 0 :(得分:1)

在你的第二个例子中,当创建Thread时,你应该只传递函数,并且args应该作为第二个参数。像这样:

Thread(target=run, args = (args.arg1, args.arg2))

因此,在您的第二个示例中,您在创建线程之前实际评估了该函数,并将None函数从run函数返回到Thread类。

此外,根据docs,指定daemon = True时:

  

这个标志的意义在于整个Python程序退出   什么时候只剩下守护程序线程

这应该有效:

def run(arg1,arg2):
    class_instance = MultiThreadClass(arg1, arg2)
    class_instance.run()

if __name__ == '__main__':
    parser = create_arg_parser()
    args = parser.parse_args()
    run_thread = Thread(target=run, args=(args.arg1, args.arg2))
    run_thread.start()
    time.sleep(args.arg3)

This帖子将帮助您开始使用主题,此外我会阅读docs以更好地理解“魔术”。