【掌握Python多线程并发编程】轻松入门高效实现

作者:用户BYRM 更新时间:2025-05-29 06:45:40 阅读时间: 2分钟

前言

在当今快速发展的互联网时代,高效率的程序执行变得尤为重要。Python作为一种广泛使用的编程语言,其多线程并发编程功能能够显著提高程序的执行效率。本文将带你轻松入门Python多线程并发编程,并展示如何高效实现。

学前须知

在开始学习之前,你需要具备以下基础:

  • Python基础语法
  • Python文件操作
  • Python模块应用

开发工具

推荐使用PyCharm作为开发工具,它具有强大的代码编辑和调试功能。

课程安排

  • 进程实现多任务
  • 线程实现多任务
  • 多任务应用

一、多任务介绍

1.1 多任务的概念

多任务是指在同一时间内执行多个任务。

1.2 多任务的两种表现形式

  • 并发:在一段时间内交替去执行多个任务。
  • 并行:在一段时间内真正的同时一起执行多个任务。

1.3 并发

例子:对于单核CPU处理多任务,操作系统轮流让各个任务交替执行。

1.4 并行

例子:对于多核CPU处理多任务,操作系统会给CPU的每个内核安排一个执行的任务,多个内核是真正的一起同时执行多个任务。

二、线程的介绍

线程是一个独立的执行流程,每个线程都有自己的堆栈空间和程序计数器,它们同时运行,但不一定按照顺序执行。

三、多线程实现多任务

3.1 线程的创建步骤

import threading

def printtime(threadName, delay):
    count = 0
    while count < 5:
        time.sleep(delay)
        count += 1
        print("%s: %s" % (threadName, time.ctime(time.time())))

try:
    thread1 = threading.Thread(target=printtime, args=("Thread-1", 2,))
    thread2 = threading.Thread(target=printtime, args=("Thread-2", 4,))
except:
    print("Error: 无法启动线程")

thread1.start()
thread2.start()

thread1.join()
thread2.join()

3.2 线程执行带有参数的任务

def worker(name, delay):
    print(f"线程 {name} 开始")
    time.sleep(delay)
    print(f"线程 {name} 完成")

thread1 = threading.Thread(target=worker, args=("Thread-1", 2,))
thread2 = threading.Thread(target=worker, args=("Thread-2", 4,))

thread1.start()
thread2.start()

thread1.join()
thread2.join()

3.3 主线程和子线程的结束顺序

  • 主线程会等待所有的子线程完成才结束。
  • 设置守护主线程:只有所有守护线程都结束,整个Python程序才会退出。

四、线程间的执行顺序

4.1 线程间的执行是无序的

4.2 例子

import threading

def print_numbers():
    for i in range(5):
        print("数字", i)

thread1 = threading.Thread(target=print_numbers)
thread2 = threading.Thread(target=print_numbers)

thread1.start()
thread2.start()

thread1.join()
thread2.join()

五、多线程-案例

5.1 需求分析

编写一个简单的网络爬虫,使用多线程同时爬取多个网页。

5.2 实现

import threading
import requests

def crawl(url):
    response = requests.get(url)
    print(f"爬取 {url} 成功")

urls = [
    "http://www.example.com",
    "http://www.example.org",
    "http://www.example.net"
]

threads = []
for url in urls:
    thread = threading.Thread(target=crawl, args=(url,))
    threads.append(thread)
    thread.start()

for thread in threads:
    thread.join()

六、进程和线程对比

6.1 关系对比

  • 进程是线程的容器。
  • 一个进程可以包含多个线程。

6.2 区别对比

  • 进程是系统进行资源分配的最小单位,而线程是进程执行程序时的最小调度单位。
  • 进程有自己独立的内存空间,而线程共享进程的内存空间。

6.3 优缺点对比

  • 进程:优点是资源独立,缺点是创建和切换开销大。
  • 线程:优点是创建和切换开销小,缺点是资源共享,存在竞争问题。

七、总结

通过本文的学习,相信你已经掌握了Python多线程并发编程的基本知识和技能。在实际应用中,合理运用多线程技术可以显著提高程序的执行效率。希望本文能帮助你轻松入门Python多线程并发编程,并在实践中不断提高自己的技能。

大家都在看
发布时间:2024-11-01 18:03
最近,听说了许多关于囊肿类疾病的产生。我相信很多朋友们对于囊种类疾病的认知还是很低,我想通过今天这个机会,好好的跟大家分析一下,关于如何治好卵巢囊肿这一问题。
发布时间:2024-12-11 05:35
西王站:中山路与长兴街交叉口东侧时光街站:中山西路时光街交叉口长城桥站:中山西路与西二环交叉口和平医院站:中山西路与友谊大街交叉口(1号线、5号线换乘站)烈士陵园站:中山西路与规划泰华街交叉口东侧新百广场站(原称“中山广场”站):中山西路与。
发布时间:2024-11-19 06:39
忆江南三首白居易 〔唐代〕江南好,风景旧曾谙;日出江花红胜火,春来江水绿如蓝。能不忆江南?江南忆,最忆是杭州;山寺月中寻桂子,郡亭枕上看潮头。何日更重游!江南忆,其次忆吴宫;吴酒一杯春竹叶,吴娃双舞醉芙蓉。早晚复相逢!诗人早年因避乱来到江南。
发布时间:2024-11-11 12:01
《封神演义》中,姜子牙的妻子马小红受炮烙之刑而死。马小红为大局着想,也为了保护自己的丈夫姜子牙,帮助他离开朝歌,她选择牺牲自己。当商王事后得知真相后,在申公豹的怂恿下对马小红使用了炮烙之刑。。
发布时间:2024-12-14 06:33
从3号口出来右转沿着沪松公路走大约400米到九新公路,左转走1公里左右就到九亭大街了。公交的话可以坐706路或者松江43路(外环)。
发布时间:2024-12-10 12:29
公交线路:地铁2号线 → 地铁4号线大兴线 → 501路,全程约21.9公里,1小时20分钟。1、从北京站乘内坐地铁2号线,经过容4站, 到达宣武门站2、乘坐地铁4号线大兴线,经过5站, 到达角门西站3、步行约340米,到达嘉园二里东门站4。
发布时间:2024-10-30 00:22
斯皮仁诺胶囊,对于这个药物名称来说,相信一部分人会有一些熟悉的情况,这是一种主要以治疗真菌感染为主的药物,可以治疗妇科阴道念珠菌感染,各种由于真菌引起的皮肤。
发布时间:2024-11-11 12:01
一本。四川师范大学是一本高校。学校是四川省属重点大学、国家首批“中西部高校基础能力建设工程”实施高校及全国深化创新创业教育改革示范校,是四川省举办本科师范教育最早、师范类院校中办学历史最为悠久的大学。学校位于四川省省会——成都市,现有狮。
发布时间:2024-12-10 09:41
公交线路:598a路,全程约55.4公里1、从临安市政府步行约1.2公里,到达临安东站2、乘坐598a路,经过3站, 到达火车东站东站3、步行约1000米,到达杭州东站。
发布时间:2024-12-13 22:55
G1339次列车属 成都局 由重庆客运段值乘。