多线程 -进程与线程概念,以及多线程代码示例

**

进程和线程的概念**

面试的时候,经常被问到 进程和线程的区别。

简单的说:进程就是运行着的程序。

我们写的python程序(或者其他应用程序比如画笔、qq等),运行起来,就称之为一个进程

在windows下面打开任务管理器,里面显示了当前系统上运行着的进程。

我们系统中有很多的进程运行着,比如qq、搜狗输入法等。
这些程序还没有运行的时候,它们的程序代码文件存储在磁盘中,就是那些扩展名为 .exe 文件。
双击它们,这些 .exe 文件就被os加载到内存中,运行起来,成为进程

而系统中每个进程里面至少包含一个 线程 。
线程是操作系统创建的,每个线程对应一个代码执行的数据结构,保存了代码执行过程中的重要的状态信息。
没有线程,操作系统没法管理和维护代码运行的状态信息。
所以没有创建线程之前,操作系统是不会执行我们的代码的。
我们前面写的Python程序,里面虽然没有创建线程的代码,但实际上,当Python解释器程序运行起来(成为一个进程),OS就自动的创建一个线程,通常称为主线程,在这个主线程里面执行代码指令。
当解释器执行我们python程序代码的时候。 我们的代码就在这个主线程中解释执行。

示例代码:



from threading import Thread, Lock
from time import sleep

bank = {
    'byhy': 0
}

bankLock = Lock()


# 定义一个函数,作为新线程执行的入口函数
def deposit(theadidx, amount):
    # 操作共享数据前,申请获取锁
    bankLock.acquire()

    balance = bank['byhy']
    # 执行一些任务,耗费了0.1秒
    sleep(0.1)
    bank['byhy'] = balance + amount
    print(f'子线程 {theadidx} 结束')

    # 操作完共享数据后,申请释放锁
    bankLock.release()


theadlist = []
for idx in range(10):
    thread = Thread(target=deposit,
                    args=(idx, 1)
                    )
    thread.start()
    # 把线程对象都存储到 threadlist中
    theadlist.append(thread)

for thread in theadlist:
    thread.join()

print('主线程结束')
print(f'最后我们的账号余额为 {bank["byhy"]}')
# 执行一下,结果如下
#
# 子线程
# 0
# 结束
# 子线程
# 1
# 结束
# 子线程
# 2
# 结束
# 子线程
# 3
# 结束
# 子线程
# 4
# 结束
# 子线程
# 5
# 结束
# 子线程
# 6
# 结束
# 子线程
# 7
# 结束
# 子线程
# 8
# 结束
# 子线程
# 9
# 结束
# 主线程结束
# 最后我们的账号余额为
# 10
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值