170 похожих чатов

Привет, не особо пойму, как устроена многопоточность с помощью модуля

threading
Допустим, у меня есть функция, довольно большая, которая делает много разной работы с сетью, результат своей работы записывает в глобальную переменную
Я так понял, что все переменные этой функции спокойно делятся между потоками (тут я вообще в шоке был)
И как быть в таком случае? Все переменные заворачивать в threading.local()?

5 ответов

12 просмотров

нет, "внутренние" переменные функции, которую ты запускаешь в отдельном потоке доступны только для нее а вот если ты запускаешь несколько таких функций в нескольких потоках, а потом работаешь с какой-то общей, глобальной переменной, то тебе нужно использовать блокировку ну или перепиши свой код так, чтобы использовать concurrect.futures.ThreadPoolExecutor, там у тебя абстракция уже не "потоки" а "фьючерсы" (мне это нравится больше ,чем называть их футурами), и они могут возвращать результаты через return как обычная функция отличие лишь в том, что для получения результата из фьючерса тебе надо его явно об этом попросить через my_future.result() этот вызов заблокирует поток выполнения до тех пор пока, вьючерс не будет завершен

Sergey Gureev
нет, "внутренние" переменные функции, которую ты з...

В функции (которая работает в 200+ потоках) есть локальные переменные, с ними вроде как всё ок, проблема с локальным массивом, он почему-то общий для всех потоков Помимо этого есть глобальный массив Глобальный массив никак не связан с локальным массивом То есть, если я уберу использование глобального массива, то и локальный массив будет по-настоящему локальным?

Я передал на concurent.futures, ничего не изменилось, ниже минимальный пример, проблема на нём сохраняется. https://pastebin.com/nuL1zw4Q

Императорская Моль 🕊 \0
Я передал на concurent.futures, ничего не изменило...

нужно вот так делать class MyClass: def __init__(self): self.arr = [] тогда для каждого нового экземпляра этого класса будет создан новый пустой список arr иначе, все твои объекты используют один и тот же список, который находится на уровне атрибутов класса, а не объекта

Похожие вопросы

Обсуждают сегодня

Не многие знают, а кто знает, тот уже успел забыть, что в далёком 2004 году эта игра произвела настоящий фурор, настолько революционной была технология, применяемая для её соз...
ICCID
4
@Aiwan что такое база образца?
Alexey
27
Хотя у меня сейчас есть более сложная задача, вот её думаю: как объяснить челу переходного возраста противоположного полу, обучающегося в польском колледже (а-ля наш техникум)...
Вячеслав Кузьменко
15
коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
30
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us We offer Interview Support for a low cost variety of technol...
Rambabu Nallamilli
3
верно что я могу удалить эти addq и subq т.к. со стеком никакого взаимодействия нет (исключая call)?
Michael
16
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
Что думаете об ассемблерах с завтипами? https://www.cs.cmu.edu/~rwh/papers/dtal/icfp01.pdf
smt model 1
7
Карта сайта