博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python多进程共享变量Value使用tips
阅读量:2396 次
发布时间:2019-05-10

本文共 802 字,大约阅读时间需要 2 分钟。

前言:

  在使用tornado的多进程时,需要多个进程共享一个状态变量,于是考虑使用multiprocessing.Value(对于该变量的具体细节请查阅相关资料)。在根据网上资料使用Value时,由于共享的是字符串,但网上介绍的都是整数或者字符,于是遇到了很多阻碍,通过查询官方文档得出了解决方案。

 

一、Value的构造函数:

  Value的初始化非常简单,直接类似Value('d'0.0)即可,具体构造方法为:

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

  该方法返回从共享内存中分配的一个 对象,其中typecode_or_type定义了返回的类型。它要么是一个ctypes类型,要么是一个代表ctypes类型的code。比如和'b'是同样的,因为'b'是的code。

  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类型可从下表查阅

  

 

转载地址:http://acfob.baihongyu.com/

你可能感兴趣的文章
内存储器管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现
查看>>
glibc-printf
查看>>
Web--JavaWeb应用中文乱码问题原理及解决方法
查看>>
Servlet--HttpServletRequest获取请求信息(请求头、请求行、参数)详解
查看>>
Web--request解决表单参数的中文乱码问题(GET方式和POST方式)
查看>>
UML--类图详解
查看>>
Servlet--关于RequestDispatcher(forward、include)的原理
查看>>
Servlet--Cookie原理及API使用详解
查看>>
Servlet--Session原理及API的使用
查看>>
Servlet--三个作用域(Request、Session、ServletContext)总结
查看>>
Listener--ServletContextListener接口的使用详解
查看>>
Listener--HttpSessionListener、ServletRequestListener接口的使用详解
查看>>
Listener--HttpSessionBindingListenerAPI及使用(在线人数统计)详解
查看>>
Struts2--非表单标签
查看>>
MyBatis--工作原理
查看>>
Maven--插件的获取和配置
查看>>
MySQL--基础四(排序查询)
查看>>
MySQL--基础五(单行函数)
查看>>
MySQL--基础六(分组函数)
查看>>
MySQL--基础七(分组查询、排序查询)
查看>>