# ThreadLocal
'''
1. 一個ThreadLocal變量雖然是全局變量,但每個線程都只能讀寫自己線程上的獨立副本,互不干擾。
2. 解決了參數(shù)在一個線程中各個函數(shù)之間互相傳遞的問題
'''
import threading
# 創(chuàng)建全局ThreadLocal對象
local_school = threading.local()
def process_student():
# 獲取當前線程關聯(lián)的student
std = local_school.student
print('Hello, %s (in %s)' % (std, threading.current_thread().name))
def process_thread(name):
# 綁定ThreadLocal的student
local_school.student = name
process_student()
t1 = threading.Thread(target=process_thread, args=('Alice',), name='Thread-A')
t2 = threading.Thread(target=process_thread, args=('Bob',), name='Thread-B')
t1.start()
t2.start()
t1.join()
t2.join()
Python:23.ThreadLocal
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
相關閱讀更多精彩內(nèi)容
- 作者:selfboot 我們知道多線程環(huán)境下,每一個線程均可以使用所屬進程的全局變量。如果一個線程對全局變量進行了...
- 在多線程環(huán)境下,每個線程都有自己的數(shù)據(jù)。一個線程使用自己的局部變量比使用全局變量好,因為局部變量只有線程自己能看見...
- ThreadLocal 分布式進程 先啟動test_master.py task_master.py進程發(fā)送完任務...
- 例1:InheritableThreadLocal 該類擴展了 ThreadLocal,為子線程提供從父線程那里繼...
- 我們知道多線程環(huán)境下,每一個線程均可以使用所屬進程的全局變量。如果一個線程對全局變量進行了修改,將會影響到其他所有...