淺談python多進(jìn)程共享變量Value的使用tips
前言:
在使用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ù)或者字符,于是遇到了很多阻礙,通過(guò)查詢官方文檔得出了解決方案。
一、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語(yǔ)言兼任的數(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)系的,就是沒(méi)有code可用。所以我們需要使用原始的ctype類型
例如
from ctypes import c_char_p
ss = Value(c_char_p, 'ss')
ctype類型可從下表查閱
以上這篇淺談python多進(jìn)程共享變量Value的使用tips就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python中pd.cut()與pd.qcut()的對(duì)比及示例
本文主要介紹了python中pd.cut()與pd.qcut()的對(duì)比及示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06對(duì)python字典過(guò)濾條件的實(shí)例詳解
今天小編就為大家分享一篇對(duì)python字典過(guò)濾條件的實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01一行Python代碼過(guò)濾標(biāo)點(diǎn)符號(hào)等特殊字符
這篇文章主要介紹了一行Python代碼過(guò)濾標(biāo)點(diǎn)符號(hào)等特殊字符的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08bpython 功能強(qiáng)大的Python shell
bpython是一個(gè)不錯(cuò)的Python解釋器的界面,本文帶著大家了解認(rèn)識(shí)一下bpython,感興趣的小伙伴們可以參考一下2016-02-02Python輪播圖與導(dǎo)航欄功能的實(shí)現(xiàn)流程全講解
這篇文章主要介紹了Python項(xiàng)目輪播圖功能實(shí)現(xiàn)和導(dǎo)航欄的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-09-09