初识线程与进程

进程

一个正在运行的程序或者软件就是一个进程,是操作系统资源分配的基本单位,每启动一个进程,操作系统就会给其分配一定的运行资源保证进程的运行
多进程效果图

多进程的使用

  • 进程包
  • 进程类
  • 进程编号
  • 进程类创建实例对象的方法和属性
  • 进程执行带有参数的任务

进程包
在这里插入图片描述

进程类
在这里插入图片描述
结果:
在这里插入图片描述

进程类创建实例对象的属性

实例对象.name:当前进程的别名,默认为Process-N,N为从1开始递增的整数,在创建进程类的时候,参数name的值

进程编号

目的:验证主进程和子进程的关系,可以得知子进程是由哪个主进程创建出来的
操作:

  • 获取当前进程编号:os.getpid()
  • 获取当前父进程编号:os.getppid()

在这里插入图片描述

进程执行带有参数的任务

  • args
  • kwargs

在这里插入图片描述

线程
线程是进程中执行代码的一个分支,线程是cpu调度的基本单位
线程运行原理
在这里插入图片描述

多线程的使用

  • 线程包
  • 线程类
  • 带参数的线程

线程类
在这里插入图片描述

设置守护主进程
目的:主进程结束,子进程也随之结束
方式:

设置守护主进程
在这里插入图片描述

销毁子进程
在这里插入图片描述

设置守护主线程

  • threading.Thread(target=show_info, daemon=True)

在这里插入图片描述

  • 线程对象.setDaemon(True)

在这里插入图片描述

线程解决避免共享数据出错

方式:

  • 线程等待

在这里插入图片描述

创建锁

  • mutex = threading.Lock()

上锁

  • mutex.acquire()
  • …这里编写代码能保证同一时刻只能有一个线程去操作, 对共享数据进行锁定…

释放锁

  • mutex.release()

注意:

  • acquire和release方法之间的代码同一时刻只能有一个线程去操作 如果在调用acquire方法的时候
    其他线程已经使用了这个互斥锁,那么此时acquire方法会堵塞,直到这个互斥锁释放后才能再次上锁 import threading

创建全局互斥锁

在这里插入图片描述

进程和线程对比方向

1.关系对比

线程是依附在进程里面的,没有进程就没有线程。
一个进程默认提供一条线程,进程可以创建多个线程
2.区别对比

进程之间不共享全局变量
线程之间共享全局变量,但是要注意资源竞争的问题,解决办法: 互斥锁或者线程同步
创建进程的资源开销要比创建线程的资源开销要大
进程是操作系统资源分配的基本单位,线程是CPU调度的基本单位
线程不能够独立执行,必须依存在进程中
多进程开发比单进程多线程开发稳定性要强
3.优缺点对比

进程优缺点:
优点:可以用多核
缺点:资源开销大
线程优缺点:
优点:资源开销小
缺点:不能使用多核

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值