在Dummy线程中调用主线程中执行Python函数

时间:2013-09-24 18:38:08

标签: python multithreading .net-remoting

我有一个Python脚本,可以处理来自.NET Remoting的异步回调。这些回调在虚拟(工作)线程中执行。从我的回调处理程序里面,我需要调用我在脚本中定义的函数,但是我需要在主线程中执行该函数。

主线程是一个向服务器发送命令的远程客户端。其中一些命令会导致异步回调。

基本上,我需要相当于.NET的Invoke方法。这可能吗?

1 个答案:

答案 0 :(得分:22)

您希望使用Queue类来设置虚拟线程使用函数填充并且主线程消耗的队列。

import Queue

#somewhere accessible to both:
callback_queue = Queue.Queue()

def from_dummy_thread(func_to_call_from_main_thread):
    callback_queue.put(func_to_call_from_main_thread)

def from_main_thread_blocking():
    callback = callback_queue.get() #blocks until an item is available
    callback()

def from_main_thread_nonblocking():
    while True:
        try:
            callback = callback_queue.get(False) #doesn't block
        except Queue.Empty: #raised when queue is empty
            break
        callback()

演示:

import threading
import time

def print_num(dummyid, n):
    print "From %s: %d" % (dummyid, n)
def dummy_run(dummyid):
    for i in xrange(5):
        from_dummy_thread(lambda: print_num(dummyid, i))
        time.sleep(0.5)

threading.Thread(target=dummy_run, args=("a",)).start()
threading.Thread(target=dummy_run, args=("b",)).start()

while True:
    from_main_thread_blocking()

打印:

From a: 0
From b: 0
From a: 1
From b: 1
From b: 2
From a: 2
From b: 3
From a: 3
From b: 4
From a: 4

然后永远阻止