1. 程式人生 > >python多程序共享變數Value使用tips

python多程序共享變數Value使用tips

前言:

  在使用tornado的多程序時,需要多個程序共享一個狀態變數,於是考慮使用multiprocessing.Value(對於該變數的具體細節請查閱相關資料)。在根據網上資料使用Value時,由於共享的是字串,但網上介紹的都是整數或者字元,於是遇到了很多阻礙,通過查詢官方文件得出瞭解決方案。

一、Value的建構函式:

  Value的初始化非常簡單,直接類似Value('d'0.0)即可,具體構造方法為:

  multiprocessing.Value(typecode_or_type*args[, lock])。

  該方法返回從共享記憶體中分配的一個ctypes

 物件,其中typecode_or_type定義了返回的型別。它要麼是一個ctypes型別,要麼是一個代表ctypes型別的code。比如c_bool和'b'是同樣的,因為'b'是

  ctypes是Python的一個外部函式庫,它提供了和C語言兼任的資料型別,可以呼叫DLLs或者共享庫的函式,能被用作在python中包裹這些庫。

  *args是傳遞給ctypes的構造引數

二、Value的使用

  對於共享整數或者單個字元,初始化比較簡單,參照下圖對映關係即可。如i = Value('i', 1), c = Value('c', '0')。

  注意,如果我們使用的code在上表不存在,則會丟擲:

    size = ctypes.sizeof(type_)

  TypeError: this type has no size

   如果共享的是字串,則在上表是找不到對映關係的,就是沒有code可用。所以我們需要使用原始的ctype型別

  例如 

  from ctypes import c_char_p

  ss = Value(c_char_p, 'ss')

  ctype型別可從下表查閱