Python多线程,线程与进程的区别,线程模块及线程的两种创建方式

liftword2个月前 (03-31)技术文章20

Python线程

线程(Thread)&多线程

轻量级进程,是操作系统进行调度的最小单位,一个线程可以是一个任务、一个程序段的一次执行过程,线程不独立占有内存空间,它在进程的内存空间中。同一个进程内,多个线程共享进程的资源,一个进程至少有一个线程。

线程也是进程中一条执行程序的执行路径,一个程序至少有一条执行路径,多线程就是程序同时执行多条路径。

线程与进程的区别

1、线程共享内存,进程独立内存;2、线程启动速度快,进程启动速度慢;3、同一个进程的线程间可以直接通信,进程间通信,须通过一个中间代理来实现;4、创建新线程较为简单,创建新进程需要对其父进程进行一次克隆;5、一个线程可以控制和操作同一线程里的其他线程,但是进程只能操作子进程。

线程的模块

Python的标准库提供了两个模块:_thread和threading,_thread是低级模块,threading是高级模块,对_thread进行了封装。

threading模块提供了一个比_thread模块更高层的API来提供线程的并发性。

线程的两种创建方式

方式一,直接使用,实例化线程对象

import threading
import time

#线程运行的函数
def run(args):
  print("我是线程%s" % args)
  time.sleep(3)
  print("线程运行结束%s" % args)

if __name__ == '__main__':
  #创建线程
  thread1 = threading.Thread(target=run,args=(1,))
  thread2 = threading.Thread(name='thread2',target=run,args=(2,))
  start_time = time.time()
  thread1.start()
  thread2.start()
  end_time = time.time()
  print("线程运行时间为:",end_time-start_time)

方式二,继承自线程类,继承式调用

继承线程的类,重写运行方法,在run()方法中编写线程的执行代码,使用线程对象的start()方法启动线程,参数传递在构造方法中,在重写的run()中使用传递的参数。

import threading
import time

class MyThread(threading.Thread):
  #初始化
  def __init__(self,name):
    super(MyThread,self).__init__()
    self.name = name
  #线程运行方法
  def run(self):
    print("我是线程%s" % self.name)
    time.sleep(3)
    print("线程运行结束%s" % self.name)   

if __name__ == '__main__':
  #创建线程
  thread1 = MyThread(1)
  thread2 = MyThread(name='thread2')
  start_time = time.time()
  thread1.start()
  thread2.start()
  end_time = time.time()
  print("线程运行时间为:",end_time-start_time)

相关文章

Python并发编程(3)——Python多线程详解介绍

左手编程,右手年华。大家好,我是一点,关注我,带你走入编程的世界。公众号:一点sir,关注领取python编程资料Python 的多线程入门是非常简单的,直接导入threading模块就可以开始多线程...

Python多线程编程到底怎么玩?核心技巧与注意事项全知道!

在 Python 中,多线程编程主要用于处理 I/O 密集型任务(如网络请求、文件读写、数据库操作等),但由于 全局解释器锁(GIL) 的存在,多线程对 CPU 密集型任务 的性能提升有限(此时建议使...

小白都看懂了,Python 中的线程和进程精讲,建议收藏

目录线程和进程一、 什么是进程 / 线程1、 引论众所周知,CPU是计算机的核心,它承担了所有的计算任务。而操作系统是计算机的管理者,是一个大管家,它负责任务的调度,资源的分配和管理,统领整个计算机硬...

Python多线程

本文重点探究以下几个问题:多线程内存共享线程类获取线程结果方法:join/setDaemon对线程退出的作用线程无法利用多核,不是真正的并发多线程内存共享多个线程访问同一内存变量时,需要通过锁机制来实...

了解 Python 中的多线程和多处理

在软件开发领域,提高应用程序的效率和性能通常是通过多线程或多处理来实现的。这些技术允许程序同时执行多个任务,从而更好地利用系统资源并加快执行时间。在 Python 中,多线程和多处理都可用于不同的场景...

python之多线程并发

前言今天呢笔者想和大家来聊聊python多线程的并发,废话就不多说了咱们直接进入主题哟。一、线程执行python的内置模块提供了两个内置模块:thread和threading,thread是源生模块,...