python char数组_Python:多处理和c_char_p数组

本文探讨了一个Python多进程应用中遇到的问题,其中三个进程尝试将字符串写入共享c_char_p数组的不同位置。然而,输出结果显示某些字符串被其他进程覆盖。代码示例展示了如何使用multiprocessing库创建进程、共享内存以及使用锁来同步访问。尽管使用了锁,但仍然出现了数据覆盖现象。目标是理解并解决这个问题,以实现期望的并发写入效果。
摘要由CSDN通过智能技术生成

我启动了3个进程,我希望它们将一个字符串放入一个共享数组中,在进程(I)对应的索引处。

看下面的代码,生成的输出是:['test 0', None, None]

['test 1', 'test 1', None]

['test 2', 'test 2', 'test 2']

为什么“test 0”被test 1覆盖,而{}被test 2覆盖?在

我想要的是(顺序并不重要):

^{pr2}$

代码:#!/usr/bin/env python

import multiprocessing

from multiprocessing import Value, Lock, Process, Array

import ctypes

from ctypes import c_int, c_char_p

class Consumer(multiprocessing.Process):

def __init__(self, task_queue, result_queue, arr, lock):

multiprocessing.Process.__init__(self)

self.task_queue = task_queue

self.result_queue = result_queue

self.arr = arr

self.lock = lock

def run(self):

proc_name = self.name

while True:

next_task = self.task_queue.get()

if next_task is None:

self.task_queue.task_done()

break

answer = next_task(arr=self.arr, lock=self.lock)

self.task_queue.task_done()

self.result_queue.put(answer)

return

class Task(object):

def __init__(self, i):

self.i = i

def __call__(self, arr=None, lock=None):

with lock:

arr[self.i] = "test %d" % self.i

print arr[:]

def __str__(self):

return 'ARC'

def run(self):

print 'IN'

if __name__ == '__main__':

tasks = multiprocessing.JoinableQueue()

results = multiprocessing.Queue()

arr = Array(ctypes.c_char_p, 3)

lock = multiprocessing.Lock()

num_consumers = multiprocessing.cpu_count() * 2

consumers = [Consumer(tasks, results, arr, lock) for i in xrange(num_consumers)]

for w in consumers:

w.start()

for i in xrange(3):

tasks.put(Task(i))

for i in xrange(num_consumers):

tasks.put(None)

我在运行python2.7.3(Ubuntu)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Python 中可以使用列表或者 numpy 数组来定义字符数组。 使用列表定义: ``` char_array = ['a', 'b', 'c'] ``` 使用 numpy 定义: ``` import numpy as np char_array = np.array(['a', 'b', 'c']) ``` 需要注意的是,numpy 默认会将数组中的元素视为数值类型,如果需要存储字符或字符串,需要指定 dtype 为 'U' 或 'S' 。 ``` char_array = np.array(['a', 'b', 'c'], dtype='U') ``` 如果你想要字符数组更类似c语言数组,可以使用c-types库中的c_char_Array_x来定义。 ``` from ctypes import * char_array = (c_char * 3)() char_array[0] = b'a' char_array[1] = b'b' char_array[2] = b'c' ``` ### 回答2: 在Python中,可以使用列表(list)来定义字符数组。列表是一种可变的有序容器,可以存储多个值,其中可以包含字符等各种数据类型。 定义一个字符数组可以通过以下方式实现: 1. 使用方括号([])和逗号(,)将字符分隔开,然后将其赋值给变量,例如: ```python characters = ['a', 'b', 'c', 'd', 'e'] ``` 这样就定义了一个名为`characters`的字符数组,其中包含了元素'a', 'b', 'c', 'd', 'e'。 2. 利用Python内置的`list()`函数,将字符串转换为字符数组,例如: ```python word = "Hello" characters = list(word) ``` 这样就将字符串"Hello"转换为字符数组,`characters`中包含了元素'H', 'e', 'l', 'l', 'o'。 3. 还可以使用循环等方式,逐个添加字符到列表中,例如: ```python characters = [] for i in range(97, 102): characters.append(chr(i)) ``` 这样就将小写字母'a'到'e'逐个添加到字符数组`characters`中。 无论是何种方式,都可以通过索引访问和修改列表中的元素,如`characters[0]`表示第一个元素,`characters[2] = 'x'`将第三个元素修改为'x'。此外,列表还具有许多内置方法用于操作和处理字符数组中的元素,例如`append()`用于在列表末尾添加元素,`remove()`用于删除指定元素等等。 总之,Python中的字符数组即通过列表定义,可以通过索引访问和修改列表中的元素,同时还具有丰富的内置方法用于操作和处理字符数组中的元素。 ### 回答3: 在Python中,我们可以使用字符串来表示字符数组。字符串是一个有序的字符序列,可以通过将字符依次排列起来来创建。以下是一些创建和操作字符串的示例: 1. 创建一个字符串数组: ```python char_array = "hello world" ``` 这里,我们使用双引号将字符序列括起来,赋给一个变量char_array。 2. 访问字符数组中的元素: ```python first_char = char_array[0] # 获取第一个字符 print(first_char) # 输出: "h" ``` 在Python中,可以通过下标来访问字符串中的特定字符,下标从0开始计数。 3. 修改字符数组中的元素: ```python char_array[6] = "W" # 将第7个字符修改为大写字母"W" print(char_array) # 输出: "hello World" ``` 请注意,字符串是不可变的,这意味着在Python中无法直接修改字符串的某个特定字符。因此,我们需要创建一个新的字符串,将需要修改的字符替换掉。 4. 字符数组的长度: ```python length = len(char_array) # 获取字符数组的长度 print(length) # 输出: 11 ``` 使用内置函数`len()`可以获得字符数组的长度。 总之,我们可以使用字符串来定义字符数组,并通过下标和内置函数对其进行操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值