当前位置: 首页 > news >正文

进程、线程及python的多线程编程

目录

一.进程、线程和并行执行

1.什么是进程、线程

注意

 2.什么是并行执行

二.python的多线程编程

threading模块

语法

 多线程编程的传参

演示

三.总结


 

一.进程、线程和并行执行

1.什么是进程、线程

现代操作系统比如Mac OS X,UNIX, Linux, Windows等,都是支持“多任务”的操作系统。
进程:就是一个程序,运行在系统之上,那么便称之这个程序为一个运行进程,并分配进程ID方便系统管理。线程:线程是归属于进程的,一个进程可以开启多个线程,执行不同的工作,是进程的实际工作最小单位。

进程就好比一家公司,是操作系统对程序进行运行管理的单位
线程就好比公司的员工,进程可以有多个线程(员工),是进程实际的工作者
操作系统中可以运行多个进程,即多任务运行
一个进程内可以运行多个线程,即多线程运行

注意

进程之间是内存隔离的,即不同的进程拥有各自的内存空间。这就类似于不同的公司拥有不同的办公场所。
线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程所拥有的内存空间的。这就好比,公司员工之间是共享公司的办公场所。

 2.什么是并行执行

并行执行的意思指的是同一时间做不同的工作。
进程之间就是并行执行的,操作系统可以同时运行好多程序,这些程序都是在并行执行。

除了进程外,线程其实也是可以并行执行的。
也就是比如一个Python程序,其实是完全可以做到:

  • 一个线程在输出:你好
  • 一个线程在输出:Hello

像这样一个程序在同一时间做两件乃至多件不同的事情,我们就称之为:多线程并行执行

二.python的多线程编程

threading模块

绝大多数编程语言,都允许多线程编程,Pyhton也不例外。Python的多线程可以通过threading模块来实现。

语法

演示

import time

def dence():
    while True:
        print("我在跳舞!")
        time.sleep(1)

def sing():
    while True:
        print("我在唱歌,啦啦啦")
        time.sleep(1)

dence()
sing()

如上图,当直接调用时,sing函数一直没有执行,因为此时程序是单线程

import time
import threading
def dence():
    while True:
        print("我在跳舞!")
        time.sleep(1) 

def sing():
    while True:
        print("我在唱歌,啦啦啦")
        time.sleep(1)
#创建跳舞和唱歌两个线程
dance_thread=threading.Thread(target=dence)
sing_thread=threading.Thread(target=sing)
#让线程干活
dance_thread.start()
sing_thread.start()

 结果是

 多线程编程的传参

需要传参的话可以通过:

  1. args参数通过元组(按参数顺序)的方式传参,元组内只有一个时,最后要有逗号
  2. 或使用kwargs参数用字典的形式传参

演示

import time
import threading
def dence(msg):
    while True:
        print(msg)
        time.sleep(1)

def sing(a):
    while True:
        print(a)
        time.sleep(1)
#创建跳舞和唱歌两个线程
dance_thread=threading.Thread(target=dence,args=("我要跳舞!",))
sing_thread=threading.Thread(target=sing,kwargs={"a":"我要唱歌"})
#让线程干活
dance_thread.start()
sing_thread.start()

结果是

三.总结

1.什么是进程
程序在操作系统内运行,即成为一个运行进程
2.什么是线程
进程内部可以有多个线程,程序的运行本质上就是由进程内部的线程在实际工作的。
3.什么是并行执行

  • 多个进程同时在运行,即不同的程序同时运行,称之为:多任务并行执行
  • 一个进程内的多个线程同时在运行,称之为:多线程并行执行

4.threading模块的使用
thread_obj = threading.Thread(target=func)创建线程对象
thread_obj.start()启动线程执行
5.如何传参

 注意传参需要:

  1. args参数通过元组(按参数顺序)的方式传参,元组内只有一个时,最后要有逗号
  2. 或使用kwargs参数用字典的形式传参

 

 

相关文章:

  • 【ESP 保姆级教程】玩转emqx认证篇④ ——使用 Redis 的密码认证
  • 东莞注塑MES管理系统具有哪些功能
  • 云上的米开朗基罗:在不确定时代,寻找建筑般的确定性
  • CSS 布局 - 水平 垂直对齐
  • 【DevOps实战|基于Jenkins与Gitlab构建企业级持续集成环境系统】(更新中未完成)
  • 【手写 Vue2.x 源码】第二十八篇 - diff算法-问题分析与patch优化
  • (转)Chrome的最小字体12px限制最终解决办法
  • 基于PyTorch 实现一个简单的 GAN 模型。仍然以绘画创作为例,假设我们要创造如下“名画”(以正弦图形为例)
  • 基于python手撕实现BP 神经网络实现手写数字识别
  • 深度解析源码之SpringMVC文件上传为什么要用POST请求还要设置请求头
  • 消息中间件如何选型 图解 Kafka vs RabbitMQ vs RocketMQ 的差异
  • 372. 超级次方
  • 盘点:2022年豆瓣评分8.0以上的计算机书籍有哪些?
  • WPF之调用Iconfont
  • FPGA:Vivado基于IP集成的计数器设计(3)
  • 【GD32F427开发板试用】+软件IIC(OLED显示)
  • 【机器学习】逻辑回归(理论)
  • SAP ABAP 代码修改自动比较对象版本一致
  • Redis应用2(Redison)
  • 【linux】之网络安全