如何在运行方法中没有循环地在Python中终止线程?

时间:2012-12-03 11:26:31

标签: python multithreading kill

课程方法很长。
为该方法创建一个线程 我怎么能杀死\终止这个帖子?
主要问题是我无法在线程 run()方法中检查 threading.Event ,因为它不包含循环。
类似的代码如下:

import time
import threading

class LongAction:
    def time_consuming_action(self):
        tmax = 600
        for i in range(tmax):
            print i
            time.sleep(1)
        time.sleep(tmax)
        self.tmax = tmax
        return "Slept well"

class LongActionThread(threading.Thread):
    def __init__(self, la_object):
        self.la = la_object
        threading.Thread.__init__(self)

    def run(self):
        self.la.time_consuming_action()


la = LongAction()
la_thread = LongActionThread(la)
la_thread.start()

# After 5 sec i've changed my mind and trying to kill LongActionThread
time.sleep(5)
print "Trying to kill LongActionThread"
la_thread.kill()

2 个答案:

答案 0 :(得分:1)

此代码工作正常,但需要从标准输出中明确刷新数据 没有找到一种方法,印刷品可以在没有冲洗的情况下工作。

import time
from multiprocessing.process import Process
import sys

class LongAction:
    def time_consuming_action(self):
        tmax = 600
        for i in range(tmax):
            print i
            time.sleep(1)
            sys.stdout.flush()
        time.sleep(tmax)
        self.tmax = tmax
        return "Slept well"
        sys.stdout.flush()

class LongActionThread(Process):
    def __init__(self, la_object):
        self.la = la_object
        Process.__init__(self)

    def run(self):
        self.la.time_consuming_action()

if __name__ == "__main__":
    la = LongAction()
    la_thread = LongActionThread(la)
    la_thread.start()

    # After 5 sec i've changed my mind and trying to kill LongActionThread
    time.sleep(5)
    print "Trying to kill LongActionThread"
    la_thread.terminate()

答案 1 :(得分:0)

虽然杀死一个线程不是一个好主意,但如果你真的必须这样做,最简单的解决方案是实现一个运行的信号量,在sub_methods中划分你耗时的方法并检查子方法之间的线程状态。

代码部分复制自this SO question

class StoppableThread(threading.Thread):
    """Thread class with a stop() method. The thread itself has to check
    regularly for the stopped() condition."""

    def __init__(self,la_object):
        super(StoppableThread, self).__init__()
        self.la = la_object
        self._stop = threading.Event()

    def stop(self):
        self._stop.set()

    def stopped(self):
        return self._stop.isSet()

    def run(self):
       self.la.time_consuming_action( self.stopped )

    class La :

      def __init__(self):
      #init here

      def time_consuming_action(self, thread_stop_callback ):

          sub_work1()

          if thread_stop_callback():
             raise 'Thread Killed ! '

          sub_work2()

          if thread_stop_callback():
             raise 'Thread Killed ! '

          sub_work3()

          #etc...