apply_async多进程

当使用`apply_async`在多进程中调用类方法时,可能会遇到问题,导致程序意外退出。详细分析了apply_async在类方法上下文中的行为及其潜在风险。
摘要由CSDN通过智能技术生成

apply_async如果调用类函数,不管里面是什么,直接退出了。

import multiprocessing
import time
import random
import sys

# print 'Testing callback:'

class M_clas():
    def mul(a, b):
        for i in range(1000):
            time.sleep(0.5*random.random())
        return a * b

def pow3(x):
    return x ** 3

if __name__ == '__main__':
    multiprocessing.freeze_support()

    PROCESSES = 4
    print('Creating pool with %d processes\n' % PROCESSES)
    pool = multiprocessing.Pool(PROCESSES)


    A = []
    B = [56, 0, 1, 8, 27, 64, 125, 216, 343, 512, 729]
    aaa=M_clas()
    r = pool.apply_async(aaa.mul, (7, 8), callback=A.append)
    r.wait()

    r = pool.map_async(pow3, range(10), callback=A.extend)
    r.wait()

    if A == B:
        print('\tcallbacks succeeded\n')
    else:
        print('\t*** callbacks failed\n\t\t%s != %s\n' % (A, B))
好的,让我来回答你的问题。 要使用apply_async修改共享内存的数组并打印数组,可以按照以下步骤操作: 1. 首先,需要导入必要的模块。我们需要使用multiprocessing模块,它提供了用于共享内存的Array类和用于异步调用的Pool类。 ```python import multiprocessing as mp ``` 2. 然后,需要定义一个函数来修改数组。这个函数可以将数组中的每个元素加上一个常数。为了检查是否正确地修改了数组,函数还会打印数组。 ```python def modify_array(array, constant): for i in range(len(array)): array[i] += constant print(array) ``` 3. 接下来,需要创建一个共享内存数组。这可以使用Array函数完成。在这个例子中,我们创建了一个整数类型的数组,并初始化了一些值。 ```python shared_array = mp.Array('i', [1, 2, 3, 4, 5]) ``` 4. 然后,需要创建一个进程池。我们将使用该池的apply_async方法异步地调用modify_array函数,同时将共享数组作为参数传递给该函数。 ```python pool = mp.Pool() pool.apply_async(modify_array, args=(shared_array, 2)) ``` 5. 最后,需要等待异步调用完成。可以使用pool.close()和pool.join()方法实现。 ```python pool.close() pool.join() ``` 这将确保异步调用完成,然后程序退出。 注意:以上代码仅供参考。使用共享内存和进程可能会涉及到线程安全和数据同步的问题。在实际应用中,需要仔细考虑和测试这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI算法网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值