Python技巧之四种多线程应用分享

作者:Python 时间:2021-12-04 12:11:57 

在Python中,多线程是实现并发的一种方式。多线程可以让程序在同一时间内进行多个任务,从而提高程序的效率和执行速度。

本文将介绍Python中多线程的所有方式,包括使用threading模块、使用concurrent.futures模块、使用multiprocessing模块以及使用asyncio模块。

1.使用threading模块

Python中的threading模块提供了多线程编程的基本支持。使用该模块可以创建和管理线程,从而实现并发执行。下面是使用threading模块实现多线程的示例代码:

import threading
def worker():
    print('Worker thread started')
    # do some work here
    print('Worker thread finished')
if __name__ == '__main__':
    print('Main thread started')
    # create a new thread
    t = threading.Thread(target=worker)
    # start the new thread
    t.start()
    print('Main thread finished')

在上面的代码中,我们首先定义了一个worker函数,该函数会在一个新的线程中执行。

然后,在主线程中创建了一个新的线程t,并将worker函数作为该线程的目标。

最后,通过调用start方法来启动新线程。运行上面的代码,输出结果如下:

Main thread started
Worker thread started
Main thread finished
Worker thread finished

从上面的输出结果可以看出,程序先执行了主线程中的代码,然后创建了一个新的线程,并在新线程中执行worker函数。

主线程和新线程是并行执行的,因此程序的执行速度得到了提高。

2.使用concurrent.futures模块

concurrent.futures模块是Python 3中的新模块,它提供了线程池和进程池的实现。使用该模块可以更方便地实现并行执行。

下面是使用concurrent.futures模块实现多线程的示例代码:

import concurrent.futures
def worker():
    print('Worker thread started')
    # do some work here
    print('Worker thread finished')
if __name__ == '__main__':
    print('Main thread started')
    # create a thread pool
    with concurrent.futures.ThreadPoolExecutor(max_workers=2) as executor:
        # submit worker function to the pool
        future = executor.submit(worker)
        print('Main thread finished')

在上面的代码中,我们首先定义了一个worker函数,该函数会在一个新的线程中执行。

然后,在主线程中创建了一个线程池executor,并设置最大线程数为2。接着,通过调用submit方法将worker函数提交给线程池。

最后,我们输出了一条信息,表示主线程已经执行完毕。运行上面的代码,输出结果如下:

Main thread started
Main thread finished
Worker thread started
Worker thread finished

从上面的输出结果可以看出,程序先执行了主线程中的代码,然后通过线程池执行了worker函数。线程池会自动管理线程的创建和销毁,从而使程序更加高效。

3.使用multiprocessing模块

Python中的multiprocessing模块提供了多进程编程的支持。使用该模块可以在不同的进程中执行任务,从而实现并发执行。

下面是使用multiprocessing模块实现多线程的示例代码:

import multiprocessing
def worker():
    print('Worker process started')
    # do some work here
    print('Worker process finished')
if __name__ == '__main__':
    print('Main process started')
    # create a new process
    p = multiprocessing.Process(target=worker)
    # start the new process
    p.start()
    print('Main process finished')

在上面的代码中,我们首先定义了一个worker函数,该函数会在一个新的进程中执行。然后,在主进程中创建了一个新的进程p,并将worker函数作为该进程的目标。

最后,通过调用start方法来启动新进程。运行上面的代码,输出结果如下:

Main process started
Main process finished
Worker process started
Worker process finished

从上面的输出结果可以看出,程序先执行了主进程中的代码,然后创建了一个新的进程,并在新进程中执行worker函数。

主进程和新进程是并行执行的,因此程序的执行速度得到了提高。

4.使用asyncio模块

Python中的asyncio模块提供了异步编程的支持。使用该模块可以实现协程,从而在单线程中实现并发执行。

下面是使用asyncio模块实现多线程的示例代码:

import asyncio
async def worker():
    print('Worker task started')
    # do some work here
    print('Worker task finished')
if __name__ == '__main__':
    print('Main task started')
    # create a new event loop
    loop = asyncio.get_event_loop()
    # run the worker coroutine
    loop.run_until_complete(worker())
    # close the event loop
    loop.close()
    print('Main task finished')

在上面的代码中,我们首先定义了一个异步函数worker,该函数会在一个协程中执行。

然后,在主任务中创建了一个新的事件循环loop,并通过调用run_until_complete方法来运行worker协程。

最后,我们关闭了事件循环。运行上面的代码,输出结果如下:

Main task started
Worker task started
Worker task finished
Main task finished

从上面的输出结果可以看出,程序先执行了主任务中的代码,然后通过事件循环执行了worker协程。

协程是在单线程中执行的,因此程序的执行速度得到了提高。

5.总结

本文介绍了Python中多线程的所有方式,包括使用threading模块、使用concurrent.futures模块、使用multiprocessing模块以及使用asyncio模块。

不同的方式适用于不同的场景,可以根据需要选择最合适的方式。

多线程编程可以提高程序的效率和执行速度,但需要注意线程安全和锁的使用。

来源:https://mp.weixin.qq.com/s/kCkKFRQoumP8PZ5zH3sqeA

标签:Python,多线程
0
投稿

猜你喜欢

  • Python中filter与lambda的结合使用详解

    2022-03-03 01:35:03
  • python实现自动登录后台管理系统

    2021-05-26 13:40:48
  • 微信小程序应用号开发教程详解

    2022-07-05 00:34:50
  • 浅谈在JupyterNotebook下导入自己的模块的问题

    2023-03-16 11:28:36
  • Mysql数据库清理binlog日志命令详解

    2024-01-14 09:04:07
  • php之php.ini配置文件讲解案例

    2023-06-11 18:19:06
  • 在Python运行时动态查看进程内部信息的方法

    2021-06-09 09:15:40
  • Ubuntu系统安装与配置MySQL

    2024-01-27 17:41:37
  • python 输出上个月的月末日期实例

    2022-11-30 16:33:11
  • 如何设置SQL Server数据库全文索引服务

    2009-01-13 13:46:00
  • Python 循环语句之 while,for语句详解

    2024-01-01 02:20:50
  • javascript下判断一个元素是否存在的代码

    2024-04-18 10:12:41
  • python pyinstaller 加载ui路径方法

    2023-06-12 23:27:20
  • Python线性网络实现分类糖尿病病例

    2022-03-13 11:23:25
  • 微软建议的ASP性能优化28条守则(8)

    2005-05-30 16:04:00
  • Python shapefile转GeoJson的2种方式实例

    2023-02-20 01:07:52
  • axios拦截器工作方式及原理源码解析

    2023-07-02 16:38:36
  • 微信小程序简单的canvas裁剪图片功能详解

    2023-08-24 07:49:20
  • Python模块介绍与使用详细讲解

    2022-08-31 02:38:33
  • python实现UDP协议下的文件传输

    2023-10-10 10:26:20
  • asp之家 网络编程 m.aspxhome.com