我想实现一个程序,该程序将在运行一段时间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
秒后终止,我对原因感到困惑。如果有人能解释所有这些背后的魔力,我也非常感激......非常感谢!
答案 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)