Pho*_*rce 5 python multithreading
我有两个线程,并且,我希望一个线程运行10秒,然后让这个线程停止,而另一个线程执行,然后第一个线程再次启动; 这个过程重复进行.所以,例如
from threading import Thread
import sys
import time
class Worker(Thread):
Listened = False;
def __init__(self):
while 1:
if(self.Listened == False):
time.sleep(0)
else:
time.sleep(20)
for x in range(0, 10):
print "I'm working"
self.Listened = True
class Processor(Thread):
Listened = False;
def __init__(self):
# this is where I'm confused!!
Worker().start()
Processer().start()
Run Code Online (Sandbox Code Playgroud)
(PS我已正确缩进,但是,似乎有点搞砸了)
基本上,我想要的是:
工作线程工作10秒钟(或左右)然后停止,"处理器"启动,一旦处理器处理了"工作"线程的最后一次运行的数据,它就重新启动"工人"搞砸了.我没有必要从当前位置重新启动"worker"线程,它可以从头开始.
有没有人有任何想法?
您可以使用计数信号量来阻塞线程,然后稍后唤醒它。
计数信号量是具有非负整数计数的对象。如果线程acquire()在计数为 0 时调用信号量,则线程将阻塞,直到信号量的计数大于零。要解除线程的阻塞,另一个线程必须通过调用信号量来增加信号量的计数release()。
创建两个信号量,一个用于阻止工作线程,一个用于阻止处理器。启动工作信号量计数 1,因为我们希望它立即运行。将处理器的信号量计数启动为 0,因为我们希望它阻塞直到工作线程完成。
将信号量传递给工作者和处理器类。工作线程运行 10 秒后,它应该通过调用 唤醒处理器processorSemaphore.release(),然后它应该通过调用 休眠其信号量workerSemaphore.acquire()。处理器也做同样的事情。
#!/usr/bin/env python
from threading import Thread, Semaphore
import sys
import time
INTERVAL = 10
class Worker(Thread):
def __init__(self, workerSemaphore, processorSemaphore):
super(Worker, self).__init__()
self.workerSemaphore = workerSemaphore
self.processorSemaphore = processorSemaphore
def run(self):
while True:
# wait for the processor to finish
self.workerSemaphore.acquire()
start = time.time()
while True:
if time.time() - start > INTERVAL:
# wake-up the processor
self.processorSemaphore.release()
break
# do work here
print "I'm working"
class Processor(Thread):
def __init__(self, workerSemaphore, processorSemaphore):
super(Processor, self).__init__()
print "init P"
self.workerSemaphore = workerSemaphore
self.processorSemaphore = processorSemaphore
def run(self):
print "running P"
while True:
# wait for the worker to finish
self.processorSemaphore.acquire()
start = time.time()
while True:
if time.time() - start > INTERVAL:
# wake-up the worker
self.workerSemaphore.release()
break
# do processing here
print "I'm processing"
workerSemaphore = Semaphore(1)
processorSemaphore = Semaphore(0)
worker = Worker(workerSemaphore, processorSemaphore)
processor = Processor(workerSemaphore, processorSemaphore)
worker.start()
processor.start()
worker.join()
processor.join()
Run Code Online (Sandbox Code Playgroud)