zoukankan      html  css  js  c++  java
  • 20-多线程学习1

    from multiprocessing.dummy import Pool as ThreadPool
    import time
    
    
    def fun(msg):
        print('msg: ', msg)
        time.sleep(1)
        print('********')
        return 'fun_return %s' % msg
    
    
    if __name__ == '__main__':
        '''
        # map_async
        print('
    ------map_async-------')
        arg = [1, 2, 10, 11, 18]
        async_pool = ThreadPool(processes=4)
        result = async_pool.map_async(fun, arg)
        print(result.ready())  # 线程函数是否已经启动了
        print('map_async: 不堵塞')
        result.wait()  # 等待所有线程函数执行完毕
        print('after wait')
        if result.ready():  # 线程函数是否已经启动了
            if result.successful():  # 线程函数是否执行成功
                print(result.get())  # 线程函数返回值
        '''
    
        '''
        # map
        print('
    ------map-------')
        arg = [3, 5, 11, 19, 12]
        pool = ThreadPool(processes=3)
        return_list = pool.map(fun, arg)
        print('map: 堵塞')
        pool.close()
        pool.join()
        print(return_list)
        '''
    
        '''
        # apply_async
        print('
    ------apply_async-------')
        async_pool = ThreadPool(processes=4)
        results = []
        for i in range(5):
            msg = 'msg: %d' % i
            result = async_pool.apply_async(fun, (msg,))
            results.append(result)
        
        print('apply_async: 不堵塞')
        for i in results:
            i.wait()  # 等待线程函数执行完毕
        
        for i in results:
            if i.ready():  # 线程函数是否已经启动了
                if i.successful():  # 线程函数是否执行成功
                    print(i.get())  # 线程函数返回值
        '''
    
    
        # apply
        print('
    ------apply-------')
        pool = ThreadPool(processes=4)
        results = []
        for i in range(5):
            msg = 'msg: %d' % i
            result = pool.apply(fun, (msg,))
            results.append(result)
        print('apply: 堵塞')
        pool.close()
        pool.join()
        print(results)
    
  • 相关阅读:
    词法分析程序
    0909关于编译原理
    深度学习中图像检测的评价标准
    【 记忆网络 1 】 Memory Network
    ssm又乱码
    百度地图标注没了
    Fragment与Activity交互(使用Handler)
    在android里用ExpandableListView实现二层和三层列表
    java中outer的使用
    android中使用Http下载文件并保存到本地SD卡
  • 原文地址:https://www.cnblogs.com/lotuslaw/p/14421700.html
Copyright © 2011-2022 走看看