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

Python中多线程和多处理的指南是怎样的

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Python中多线程和多处理的指南是怎样的

Python中多线程和多处理的指南是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

使用Python分析数据,如果使用了正确的数据结构和算法,有时可以大量提高程序的速度。实现此目的的一种方法是使用Muiltithreading(多线程)或Multiprocessing(多重处理)。

使用Python分析数据,如果使用了正确的数据结构和算法,有时可以大量提高程序的速度。实现此目的的一种方法是使用Muiltithreading(多线程)或Multiprocessing(多重处理)。

我们举一个例子,编写一个小的Python脚本从Unsplash下载图像。我们将从一次下载一个图像的版本开始。接下来,我们使用线程来提高执行速度。

Python中多线程和多处理

多线程

简单地说,线程允许您并行地运行程序。花费大量时间等待外部事件的任务通常适合线程化。它们也称为I/O Bound任务例如从文件中读写,网络操作或使用API在线下载。让我们来看一个示例,它展示了使用线程的好处。

1. 没有线程

在本例中,我们希望通过顺序运行程序来查看从Unsplash API下载15张图像需要多长时间:

import requests import time img_urls = [     'https://images.unsplash.com/photo-1516117172878-fd2c41f4a759',     'https://images.unsplash.com/photo-1532009324734-20a7a5813719',     'https://images.unsplash.com/photo-1524429656589-6633a470097c',     'https://images.unsplash.com/photo-1530224264768-7ff8c1789d79',     'https://images.unsplash.com/photo-1564135624576-c5c88640f235',     'https://images.unsplash.com/photo-1541698444083-023c97d3f4b6',     'https://images.unsplash.com/photo-1522364723953-452d3431c267',     'https://images.unsplash.com/photo-1513938709626-033611b8cc03',     'https://images.unsplash.com/photo-1507143550189-fed454f93097',     'https://images.unsplash.com/photo-1493976040374-85c8e12f0c0e',     'https://images.unsplash.com/photo-1504198453319-5ce911bafcde',     'https://images.unsplash.com/photo-1530122037265-a5f1f91d3b99',     'https://images.unsplash.com/photo-1516972810927-80185027ca84',     'https://images.unsplash.com/photo-1550439062-609e1531270e',     'https://images.unsplash.com/photo-1549692520-acc6669e2f0c' ]  start = time.perf_counter() #start timer for img_url in img_urls:     img_name = img_url.split('/')[3] #get image name from url     img_bytes = requests.get(img_url).content with open(img_name, 'wb') as img_file:      img_file.write(img_bytes) #save image to disk   finish = time.perf_counter() #end timer print(f"Finished in {round(finish-start,2)} seconds")   #results Finished in 23.101926751 seconds

一共用时23秒。

2. 多线程

让我们看看Pyhton中的线程模块如何显著地改进我们的程序执行:

import time from concurrent.futures import ThreadPoolExecutor  def download_images(url):     img_name = img_url.split('/')[3]     img_bytes = requests.get(img_url).content     with open(img_name, 'wb') as img_file:          img_file.write(img_bytes)          print(f"{img_name} was downloaded")  start = time.perf_counter() #start timer with ThreadPoolExecutor() as executor:     results = executor.map(download_images,img_urls) #this is Similar to map(func, *iterables) finish = time.perf_counter() #end timer print(f"Finished in {round(finish-start,2)} seconds")  #results  Finished in 5.544147536 seconds

我们可以看到,与不使用线程代码相比,使用线程代码可以显著提高速度。从23秒到5秒。

对于本例,请注意在创建线程时存在开销,因此将线程用于多个API调用是有意义的,而不仅仅是单个调用。

此外,对于密集的计算,如数据处理,图像处理多处理比线程执行得更好。

看完上述内容,你们掌握Python中多线程和多处理的指南是怎样的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

免责声明:

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

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

Python中多线程和多处理的指南是怎样的

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

下载Word文档

猜你喜欢

Python中多线程和多处理的指南是怎样的

Python中多线程和多处理的指南是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。使用Python分析数据,如果使用了正确的数据结构和算法,有时可以大量提高程序的速度。实
2023-06-05

Python中多线程和多处理的分析

本篇内容主要讲解“Python中多线程和多处理的分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中多线程和多处理的分析”吧!多线程简单地说,线程允许您并行地运行程序。花费大量时间等
2023-06-16

Python中多处理与多线程的区别是什么

Python中多处理与多线程的区别是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。什么是线程?你为什么想要它?Python是一种线性语言。但是,当您需要更多的处理能力时,线
2023-06-16

Python多线程应用程序的优化实战指南

实战指南:如何优化Python多线程应用程序,需要具体代码示例引言:随着计算机性能的不断提升,多线程应用程序成为了开发者们提高程序运行效率的重要手段之一。而Python作为一种易于学习和使用的高级编程语言,也提供了多线程编程的支持。然而,
Python多线程应用程序的优化实战指南
2024-01-13

C语言编程中的thread多线程是怎样的

本篇文章为大家展示了C语言编程中的thread多线程是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。线程创建与结束C++11 新标准中引入了四个头文件来支持多线程编程,他们分别是
2023-06-21

Python中的多进程编程和多线程编程的区别是什么?

Python中的多进程编程和多线程编程的区别是什么?在Python中,多进程编程和多线程编程都是实现并行计算的方法。虽然它们都能同时运行多个任务,但其底层原理和使用方式却有所不同。多进程编程是利用操作系统的多进程机制来实现并行计算的。在Py
2023-10-22

Java多线程发展史是怎样的

本篇内容主要讲解“Java多线程发展史是怎样的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java多线程发展史是怎样的”吧!JDK 1.01996年1月的JDK1.0版本,从一开始就确立了Ja
2023-06-17

python多线程处理循环的方法是什么

在Python中,有多种方法可以使用多线程处理循环。以下是两种常用的方法:1. 使用`threading.Thread`类:可以通过创建多个`Thread`对象,每个对象处理一个循环迭代,从而实现多线程处理循环。每个线程对象可以通过调用`s
2023-10-07

Python 多线程与多进程:进阶指南,解锁并发编程的更多可能性

Python 多线程与多进程是两种重要的并发编程技术,它能够充分利用计算机的处理能力,提高程序的执行效率。本文将深入探讨 Python 多线程和多进程的原理、使用方式以及常见的应用场景,帮助你解锁并发编程的更多可能性。
Python 多线程与多进程:进阶指南,解锁并发编程的更多可能性
2024-02-24

Python中的多进程编程和多线程编程在不同场景下的适用性和性能差异是怎样的?

Python中的多进程编程和多线程编程在不同场景下的适用性和性能差异是怎样的?在Python中,多进程编程和多线程编程都是为了实现并行计算而存在的。然而,它们在适用性和性能上有一些不同之处。为了更好地理解它们的区别,我们将从适用性和性能两个
2023-10-26

python中多进程和多线程的使用方法

这篇文章主要介绍了python中多进程和多线程的使用方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。进程和线程进程是系统进行资源分配的最小单位,线程是系统进行调度执行的最小
2023-06-14

python中的多进程处理

众所周知,python本身是单线程的,python中的线程处理是由python解释器分配时间片的;但在python 3.0中吸收了开源模块,开始支持系统原生的进程处理——multiprocessing.注意:这个模块的某些函数需要操作系统的
2023-01-31

PHP开发中的多线程编程和并发处理

php的多线程编程和并发处理提供了以下技术:创建线程(pthread_create())并等待其完成(pthread_join())。通过互斥锁(pthread_mutex_lock() 和 pthread_mutex_unlock())同
PHP开发中的多线程编程和并发处理
2024-05-09

Python中多线程、多进程、协程的区别是什么

今天就跟大家聊聊有关Python中多线程、多进程、协程的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先我们写一个简化的爬虫,对各个功能细分,有意识进行函数式编程。下面代
2023-06-16

python爬虫中多线程和多进程的示例分析

小编给大家分享一下python爬虫中多线程和多进程的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最初的设计是用于
2023-06-14

Python开发注意事项:处理多线程和多进程时的注意事项

Python开发注意事项:处理多线程和多进程时的注意事项在Python开发过程中,使用多线程和多进程可以充分利用计算机的多核处理能力,提高程序的效率和性能。然而,使用多线程和多进程也会带来一些潜在的问题和挑战,开发者需要注意一些注意事项来确
Python开发注意事项:处理多线程和多进程时的注意事项
2023-11-22

Python中的多线程怎么实现

本文小编为大家详细介绍“Python中的多线程怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python中的多线程怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言:多线程简单理解就是:一个CP
2023-07-02

java中多线程的原理是什么

java中多线程的原理是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java基本数据类型有哪些Java的基本数据类型分为:1、整数类型,用来表示整数的数据
2023-06-14

编程热搜

  • 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动态编译

目录