问题描述
我一直在为这个整个劳动节长周末而奋斗。下面的代码不会以Ctrl-C停止。我必须做些脑死的事,再也看不到了。它不仅不会停止,而且我从没收到信号处理程序消息,
DateTime
我听到诸如“被阻止”之类的术语,但我不知道它们的含义。我的SIGTERM是否被“阻止”了?我也不明白killpill.wait和killpill.is_set()之间的区别。但是,这似乎是一个次要问题。由于我似乎从来没有发现过SIGTERM,因此killpill方法应该无关紧要。
我正在Windows 10上使用Python 3.8.5,并在PowerShell中运行。
"Interrupted by %d,shutting down"
任何有帮助的见解将不胜感激。输出是
import signal
import logging
import threading
logging.basicConfig(level=logging.DEBUG,format='[%(levelname)s] (%(threadName)-10s) %(message)s')
def quit(signo,_frame): # Graceful exit when we get ^C
print("Interrupted by %d,shutting down" % signo)
killpill.set()
def doit():
try:
while not(killpill.wait(1)):
logging.debug( "starting ... " + str( killpill.is_set() ))
time.sleep(1)
logging.debug( "working ... " + str( killpill.is_set()) )
except KeyboardInterrupt:
logging.debug("KeyboardInterrupt stopping mouse_info")
def main():
global killpill
killpill = threading.Event()
t1=threading.Thread(name='t1',target=doit)
t1.daemon=True
t1.start()
t1.join()
while True:
time.sleep(1)
if (__name__ == '__main__'):
for sig in ('TERM','INT','BREAK','ABRT'):
signal.signal(getattr(signal,'SIG'+sig),quit)
main()
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)