我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python中并发、进程、线程的总结

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python中并发、进程、线程的总结

并发

同时做某些事,但是强调,一段时间内有事情要处理。


并发的解决

1:队列、缓冲区

使用队列解决资源使用的问题,先进先出,其实就是一个缓冲区。

2:争抢

抢到资源就上锁,排他性的锁,其它只能等候。

3:预处理

提前加载用户需要的数据,缓存。

4:并行

通过多开进程、线程实现并行处理,购买更多的服务器来解决问题。(水平扩展)

5:提速

提高性能,(垂直扩展)

6:消息中间件

常见的消息中间件有RabbitMQ、ActiveMQ、RocketMQ、kafka


进程

计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。


线程

线程有时也被称为轻量级进程,是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。


进程和线程的关系

程序是源代码编译后的文件,而这些文件存放在磁盘上。当程序被操作系统加载到内存中,就是进程,进程中存放着指令和数据(资源),它也是线程的容器。


Linux进程有父进程、子进程,windows的进程是平等关系。


线程的状态


就绪(Ready):线程能够运行,但在等待被调度。可能线程刚刚创建启动,或者刚刚从阻塞中恢复,或者被其他线程抢占

运行(Running):线程正在运行

阻塞(Blocked) :线程等待外部事件发生而无法运行,如I/O操作

终止(Terminated):线程完成,或者退出,或被取消



Python中的线程开发使用标准库threading

Thread类


参数:

target:线程调用的对象,就是目标函数

name:为线程起一个名字

args:为目标函数传递实参,元组

kwargs:为目标函数关键字传参,字典



线程的启动

需要调用start()方法。


线程的退出

Python没有提供线程退出的方法,线程在下面情况时退出

1:线程函数内语句执行完毕

2:线程函数中抛出未处理的异常



线程的传参

本质上就是函数传参。


threading的属性和方法

方法:

current_thread():返回当前线程对象

main_thread():返回主线程对象

active_count():当前处于alive状态的线程个数

enumerate():返回所有活着的线程的列表,不包括已经终止的线程和未开始的线程

get_ident():返回当前线程的ID,非0整数


Thread实例的属性和方法

name:只是一个名字,只是个标识,名称可以重名。getName(),setName()获取、设置这个名词

ident:线程ID,它时非0整数。线程启动后才会有ID,否则为None.线程退出,此ID依旧可以访问,此ID可以重复使用。

is_alive():返回线程是否或着


start():启动线程,每一个线程必须且只能执行该方法一次


run():运行线程函数


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python中并发、进程、线程的总结

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python中并发、进程、线程的总结

并发同时做某些事,但是强调,一段时间内有事情要处理。并发的解决1:队列、缓冲区使用队列解决资源使用的问题,先进先出,其实就是一个缓冲区。2:争抢抢到资源就上锁,排他性的锁,其它只能等候。3:预处理提前加载用户需要的数据,缓存。4:并行通过多
2023-01-31

Python控制多进程与多线程并发数总结

一、前言本来写了脚本用于暴力破解密码,可是1秒钟尝试一个密码2220000个密码我的天,想用多线程可是只会一个for全开,难道开2220000个线程吗?只好学习控制线程数了,官方文档不好看,觉得结构不够清晰,网上找很多文章也都不很清晰,只有
2022-06-04

Python中多线程总结

Python中的多线程多线程一个进程中有多个线程就是多线程。一个进程中至少有一个线程,并作为程序的入口,这个就是主线程。一个进程至少有一个主进程,其他线程称为工作线程。线程安全:线程执行一段代码,不会产生不确定的结果,那这段代码就是线程安全
2023-01-31

Python并发编程之线程池/进程池

原文来自开源中国前言python标准库提供线程和多处理模块来编写相应的多线程/多进程代码,但当项目达到一定规模时,频繁地创建/销毁进程或线程是非常消耗资源的,此时我们必须编写自己的线程池/进程池来交换时间空间。但是从Python3.2开始,
2023-06-02

Java多线程和并发常见问题总结

这篇文章主要讲解了“Java多线程和并发常见问题总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java多线程和并发常见问题总结”吧!Java多线程问题1:进程和线程之间有什么不同?一个进
2023-06-17

七、并发编程(进程与线程)

一、前言进程即正在执行的一个过程。进程是对正在运行程序的一个抽象。进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一。操作系统的其他所有内容都是围绕进程的概念展开的。   PS:即使可以利用的
2023-01-30

Python进阶之多线程的实现方法总结

在python中主要有两种实现多线程的方式:通过threading.Thread () 方法创建线程和通过继承 threading.Thread 类的继承重写run方法,接下来我们分别说一下多线程的两种实现形式吧
2023-05-16

Python 并发编程-进程

Process类参数介绍group  --------  参数未使用, 值始终为Nonetarget  --------  表示调用对象, 即子进程要执行的任务args  ----------  表示调用对象的位置参数元组, args=(1
2023-01-30

C++并发编程:如何进行并发数据结构的线程安全设计?

线程安全并发数据结构设计:实现方式:原子类型和互斥锁原子类型:确保多个访问不可分割,保证数据一致性。互斥锁:限制一次一个线程访问共享数据,防止并发数据损坏。实例:线程安全队列展示了使用互斥锁实现的线程安全数据结构。C++并发编程:线程安全并
C++并发编程:如何进行并发数据结构的线程安全设计?
2024-05-03

Python并发编程:探索多线程和多进程的奥秘

探索Python并发编程的奥秘,掌握多线程与多进程魅力,释放程序性能新高度。 Python、并发编程、多线程、多进程、协程 在计算机科学领域,并发编程一直备受关注,它通过同时执行多个任务来提升程序性能,其中Python作为一门功能丰富的编程语言,也在并发编程方面提供了强大的支持。本文将深入探究Python并发编程,重点阐述多线程和多进程技术的原理与应用,帮助您掌握并发编程技巧,释放程序性能新高度。
Python并发编程:探索多线程和多进程的奥秘
2024-02-05

Python 并发编程中线程与进程的对比:何时使用哪种

Python 中的并发编程提供了两种强大的技术:线程和进程。了解它们的差异对于选择正确的工具以满足您的应用程序需求至关重要。
Python 并发编程中线程与进程的对比:何时使用哪种
2024-02-18

Java多线程并发、并行、线程与进程实例分析

本篇内容介绍了“Java多线程并发、并行、线程与进程实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、并发与并行并发:指两个或多个事
2023-07-02

JUC并发编程中进程与线程的示例分析

这篇文章将为大家详细讲解有关JUC并发编程中进程与线程的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。进程与线程进程程序由指令和数据组成,但这些指令要运行,数据要读写,就必须将指令加载至 CPU,
2023-06-29

iOS开发中多线程的安全隐患总结

资源共享 1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源 比如多个线程访问同一个对象、同一个变量、同一个文件 当多个线程访问同一块资源时,很容易引发数据错乱和数据安全问题 一、解决方案 解决方案:使用线程同步技术(同步,就
2022-05-27

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录