在Windows下使用python的subprocess.Popen创建子进程时,子进程如果是控制台程序(子系统为console的程序),便会继承父进程的控制台窗口
当子进程在运行时,如果在控制台使用Ctrl+C向父进程发送信号,这时会让子进程先捕捉到这个信号,造成子进程的退出。父进程是在子进程之后捕捉到这个信号的(在python里会引发KeyboardInterrupt异常)。
如果这时父进程和子进程正在通信,父进程会得到子进程通信通道关闭的消息(比如TCP连接被对方强制关闭)
后来我在Popen的STARTUPINFO参数里加了CRATE_NEW_CONSOLE标志,以为这样可以创建一个新的子窗口,以便父子进程分开捕获Ctrl+C信号,不过还是不行,不知道这是Windows的bug还是subprocess模块的bug还是系统机制本身就不允许这样
目前的解决办法是在子进程里正确处理Ctrl+C信号,以免发生意外情况