Python3-列表(容器)当做实参传递到线程中(暂未加锁)

本文通过一个具体的实例展示了如何使用Python的threading模块来实现多线程下载任务。在该示例中,所有线程共享下载任务列表,并且在下载完成后更新已完成任务列表,同时实时显示下载进度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#列表(容器)当做实参传递到线程中(暂未加锁)

#总结:
    '''
    在一个进程内的所有线程共享全局变量,能够在不适用其它方式的前提下完成多线程之间的数据共享
    缺点:线程是对全局变量的随意更改可能造成多线程之间对全局变量引用比较混乱(线程安全成了问题)
    '''

import threading
import time,random,copy

def work1(download_list,finish_list):
    # #在子线程中可以对列表进行增删改查
    # for i in range(len(num)):
    #     print('——in work1--num:%d'%num[i])
    # time.sleep(1)
    # num.remove(num[0])
    # num.append(44)
    # print(num)
    #每次从下载列表当中去取第一个,进行下载
    copy_list=copy.copy(download_list)
    for file in copy_list:


        print('——in work1--download:%d' %file)
        time.sleep(random.random())


        #下载完成之后
        #1、任务列表中移除已经下载的元素
        download_list.remove(file)
        #将已经完成的任务添加到finish_list
        finish_list.append(file)

if __name__ == "__main__":
    # 下载任务列表
    download_list=[11,22,33]
    total=len(download_list)
    #完成任务列表
    finish_list=[]

    #下载进度
    # progress = (len(finish_list) / len(download_list)) * 100
    #线程
    t1=threading.Thread(target=work1,args=(download_list,finish_list))
    t1.start()
    #获取下载进度
    while True:
        print(download_list, finish_list)
        time.sleep(1)
        progress = (len(finish_list) / total)*100
        print('当前下载进度为:%.2f %%'%progress)
        time.sleep(0.5)
        if progress == 100:
            print("全部任务下载完成!")
            break

——in work1--download:11
[11, 22, 33] []
——in work1--download:22
当前下载进度为:33.33 %
——in work1--download:33
[33] [11, 22]
当前下载进度为:100.00 %
全部任务下载完成!


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值