Найти - Пользователи
Полная версия: Потоки и синхронизированный доступ к элементам массива
Начало » Python для экспертов » Потоки и синхронизированный доступ к элементам массива
1
bobrob
Подскажите, пожалуйста, по следующему вопросу.
Мне надо вывести элементы массива в многопоточном режиме, причём, потоки не должны иметь доступа к уже используемым или использованным элементам массива.
Посмотрел доки, написал следующий код:
import threading
import time
arr = ["Item1", "Item2", "Item3",
"Item4", "Item5", "Item6", "Item7"]
def iter(thread):
while len(arr) > 0:
time.sleep(0.01)
print "thread [%d] - %s" % (thread, arr.pop(0))

class MyThread(threading.Thread):
def __init__(self):
super(MyThread, self).__init__()
self.threadID = None
def run(self):
threading.Lock().acquire()
iter(self.threadID)
threading.Lock().release()
for x in range(3):
t = MyThread()
t.threadID = x
t.start()
С задачей скрипт справляется, потоки выводят элементы массива, не повторяя их:
thread - Item1
thread - Item2
thread - Item3
thread - Item4
thread - Item5
thread - Item6
thread - Item7

Но в конце вылазит ошибка:
Exception in thread Thread-2:
Traceback (most recent call last):
File "C:\Python25\lib\threading.py", line 462, in __bootstrap
self.run()
File "c:\Python-Coding\classTest1\threads.py", line 18, in run
iter(self.threadID)
File "c:\Python-Coding\classTest1\threads.py", line 10, in iter
print "thread [%d] - %s" % (thread, arr.pop(0))
IndexError: pop from empty list
Exception in thread Thread-3:
Traceback (most recent call last):
File "C:\Python25\lib\threading.py", line 462, in __bootstrap
self.run()
File "c:\Python-Coding\classTest1\threads.py", line 18, in run
iter(self.threadID)
File "c:\Python-Coding\classTest1\threads.py", line 10, in iter
print "thread [%d] - %s" % (thread, arr.pop(0))
IndexError: pop from empty list
Exception in thread Thread-1:
Traceback (most recent call last):
File "C:\Python25\lib\threading.py", line 462, in __bootstrap
self.run()
File "c:\Python-Coding\classTest1\threads.py", line 19, in run
threading.Lock().release()
error: release unlocked lock
Где допущена ошибка и как её забороть?
crchemist
>>> import Queue
>>> help(Queue)
shiza
Ты эта… каждый раз создаешь новый объект блокировки.
threading.Lock().acquire()
threading.Lock().release()
Создай нужный объект глобально и потом уже юзай его.
l = threading.Lock()
.....
l.acquire()
.....
.release()
This is a "lo-fi" version of our main content. To view the full version with more information, formatting and images, please click here.
Powered by DjangoBB