练习多进程使用了python的multiprocessing包,
已经在if name=='__main__':下添加freeze_support(),在解释器上运行一切正常,代码中创建一个进程实际就是创建一个进程,但是在打包之后不一样
打包后的程序每当(在代码中)启动一个新进程的时候,例如ala=Process(target=startout, args=(seconds,name))
会实际上启动两个进程,而ala接收到的是父进程的实例,于是在试图手动中途停止某个进程的时候会使子进程变成孤儿进程占用系统资源。
查了很久没有发现通过父进程实例获得子进程pid的方法,也没有发现可以结束进程树的win32api,求结束子进程的正确方法或者使打包后的程序只生成一个进程的方法。
大致代码如下:
from multiprocessing import Process,freeze_support
import time
import winsound
import string
def startout(seconds,name):
print name+':pid '+str(os.getpid())+' is created'
startTime=time.time()
while (time.time()-startTime)<seconds:
time.sleep(1)
winsound.PlaySound('SystemQuestion', winsound.SND_ALIAS)
class alarmCenter:
def __init__(self):
self.alarmList={'alarm1':None,'alarm2':None,'alarm3':None}
def newAlarm(self,seconds,name):
if self.alarmList[name]!=None:
if self.alarmList[name].is_alive():
return False
ala=Process(target=startout, args=(seconds,name))
ala.deamon=True
ala.start()
self.alarmList[name]=ala
return True
def stopAlarm(self,name):
try:
print name+':pid '+\
str(self.alarmList[name].pid)+' is terminating'
self.alarmList[name].terminate()
self.alarmList[name].join()
self.alarmList[name]=None
except Exception:
pass
def terminateAll(self):
for each in self.alarmList.keys():
if self.alarmList[each]!=None:
self.alarmList[each].terminate()
查找用户名。
http://blog.csdn.net/sx5486510/article/details/8437521
请问下,你这个问题解决了吗?
这个问题解决了嘛?同问