前言:
在使用tornado的多進(jìn)程時(shí),需要多個(gè)進(jìn)程共享一個(gè)狀態(tài)變量撵术,于是考慮使用multiprocessing.Value(對(duì)于該變量的具體細(xì)節(jié)請(qǐng)查閱相關(guān)資料)背率。在根據(jù)網(wǎng)上資料使用Value時(shí),由于共享的是字符串嫩与,但網(wǎng)上介紹的都是整數(shù)或者字符寝姿,于是遇到了很多阻礙,通過查詢官方文檔得出了解決方案划滋。
一饵筑、Value的構(gòu)造函數(shù):
Value的初始化非常簡(jiǎn)單,直接類似Value('d', 0.0)即可处坪,具體構(gòu)造方法為:
multiprocessing.Value(typecode_or_type, *args[, lock])
該方法返回從共享內(nèi)存中分配的一個(gè)ctypes
對(duì)象,其中typecode_or_type定義了返回的類型根资。它要么是一個(gè)ctypes類型架专,要么是一個(gè)代表ctypes類型的code。比如c_bool
和'b'是同樣的嫂冻,因?yàn)?b'是c_bool
的code胶征。
ctypes是Python的一個(gè)外部函數(shù)庫(kù),它提供了和C語言兼任的數(shù)據(jù)類型桨仿,可以調(diào)用DLLs或者共享庫(kù)的函數(shù)睛低,能被用作在python中包裹這些庫(kù)。
*args是傳遞給ctypes的構(gòu)造參數(shù)
二服傍、Value的使用
對(duì)于共享整數(shù)或者單個(gè)字符钱雷,初始化比較簡(jiǎn)單,參照下圖映射關(guān)系即可吹零。如i = Value('i', 1), c = Value('c', '0')
罩抗。
注意,如果我們使用的code在上表不存在灿椅,則會(huì)拋出:
>> size = ctypes.sizeof(type_)
TypeError: this type has no size
如果共享的是字符串套蒂,則在上表是找不到映射關(guān)系的,就是沒有code可用茫蛹。所以我們需要使用原始的ctype類型
例如
from ctypes import c_char_p
ss = Value(c_char_p, 'ss')
ctype類型可從下表查閱