Что может вызвать задержку в моем рабочем потоке Queue.get()?

Примечание: это тесно связано с моей другой темой здесь и здесь, но это независимый вопрос, и вам не нужно читать их, если вам это не интересно..

У меня есть некоторые неожиданные задержки при обработке элементов из очереди. Кажется, это связано с потоком GUI matplotlib, потому что я могу сделать задержку произвольно долгой, избегая генерации каких-либо событий GUI, но, например, если я создаю некоторые события перемещения мыши, я могу попасть в очередь. В чем причина этой задержки и как ее исправить?

# ~/repo/wim/mpl_q.py
import threading, Queue, time, random, sys

t0 = time.time()
t = lambda : time.time() - t0

def worker():
  while True:
    thing = queue.get()
    sys.stdout.write('({0}) hello {1}!\n'.format(t(), thing))
    queue.task_done()

queue = Queue.Queue()
thread = threading.Thread(target=worker)
thread.daemon = True
thread.start()

def say_hello(thing='world'):
  print '({0}) --> say_hello({1})'.format(t(), thing)
  queue.put(thing)

say_hello('world')
say_hello('cruel world')
say_hello('stack overflow')

import matplotlib.pyplot as plt
fig = plt.figure()

def event_handler(event):
  world = random.choice(['foo', 'bar', 'baz'])
  say_hello(world)

event_handler_ = lambda x: event_handler(x)
cid0 = fig.canvas.mpl_connect('key_press_event', event_handler)
cid1 = fig.canvas.mpl_connect('button_press_event', event_handler_)

plt.show()

Пример типичного вывода, вы можете увидеть, что скриптовые элементы происходят вовремя, но сгенерированные пользователем могут появиться намного позже..

wim@wim-acer:~/repo/wim$ python mpl_q.py
(0.000166893005371) --> say_hello(world)
(0.000200986862183) --> say_hello(cruel world)
(0.000216960906982) hello world!
(0.000231027603149) --> say_hello(stack overflow)
(0.000247955322266) hello cruel world!
(0.00425505638123) hello stack overflow!
(7.80911588669) --> say_hello(foo)
(7.84842705727) hello foo!
(9.41998004913) --> say_hello(baz)
(11.4023530483) hello baz!
(14.3315930367) --> say_hello(foo)
(19.4317750931) hello foo!
(20.96124506) --> say_hello(bar)
(23.2277729511) --> say_hello(baz)
(23.2278220654) hello bar!
(29.0094120502) hello baz!

редактировать: я использую GTKAgg бэкэнд и matplotlib версия 1.1.0

1 ответ

Решение

Я не знаю почему, но проблема, кажется, исчезнет, ​​если вы объявите matplotlib.use(backend) перед импортом pyplot:

import matplotlib
matplotlib.use('TkAgg')
import matplotlib.pyplot as plt

В интерактивном сеансе проблему также можно избежать, включив интерактивный режим:

import matplotlib.pyplot as plt
plt.ion()
Другие вопросы по тегам