【问题标题】:atexit handler not responding to signalsatexit 处理程序没有响应信号
【发布时间】:2018-02-10 16:15:00
【问题描述】:

我有两个 python 文件:

a.py:

import subprocess, time, os, signal

myprocess = subprocess.Popen("b.py", shell=True)
time.sleep(2)
os.kill(myprocess.pid, signal.SIGTERM)

b.py:

import atexit

def cleanup():
    print "Cleaning up things before the program exits..."

atexit.register(cleanup)

print "Hello world!"

while True:
    pass

a.py 正在生成 b.py 并在 2 秒后终止进程。问题是我希望 cleanup 函数在它被杀死之前调用 b.py 但我无法让它工作。

我还在os.kill 函数中尝试了SIGKILLSIGINT,但对我都没有用。

当前输出(a.py):

Hello, World!
(2 seconds later, program ends)

预期输出(a.py):

Hello, World!
(2 seconds later)
Cleaning up things before the program exits...
(program ends)

【问题讨论】:

  • 你在什么平台上?
  • Windows,但将来也可能是 Linux。

标签: python windows signals interrupt kill


【解决方案1】:

为 Windows 平台使用不同的信号:signal.CTRL_C_EVENT

a.py多加些睡眠,否则子进程在父进程退出前没有机会清理:

import subprocess, time, os, signal
myprocess = subprocess.Popen("b.py", shell=True)
time.sleep(2)
os.kill(myprocess.pid, signal.CTRL_C_EVENT)
time.sleep(2)

如果您实际上不需要 shell 功能,我也想劝阻您不要使用 shell:

import subprocess, time, os, signal, sys
myprocess = subprocess.Popen([sys.executable, "b.py"])

Linux/macOS 用户:signal.CTRL_C_EVENT 不存在,你想要signal.SIGINT

【讨论】:

  • 我明白为什么这是有道理的,但它仍然无法正常工作...您自己测试过吗,它对您有用吗?
  • 是的,我自己测试过,它可以在 macOS 上运行。我没有可用的窗口框。
  • 其实可以试试signal.CTRL_C_EVENT或者signal.CTRL_BREAK_EVENT吗?这些东西非常依赖于平台,信号在 Windows 上具有不同的可用性。
  • 行得通!你知道signal.CTRL_C_EVENT 是否适用于 linux 吗?非常感谢你! :)
  • 否(Linux 上甚至不存在)。 signal.CTRL_C_EVENT 仅适用于 Windows。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-06-19
  • 2012-05-05
  • 2013-06-16
  • 2014-04-22
相关资源
最近更新 更多