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

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

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中的多线程详解,让你的程序飞起来!

Python是一门高级编程语言,拥有简单易用、面向对象、可扩展等优点,因此被广泛应用于各种领域。但是在Python中,由于GIL(全局解释器锁)的存在,导致了多线程的效率不高。但是,对于某些IO密集型...

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

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

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

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

Python多线程

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

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

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

Python 多线程居然是——假的?

作者:李晓飞来源:Python 技术不过最近有位读者提问:Python 的多线程真是假的吗?一下子点到了 Python 长期被人们喜忧参半的特性 —— GIL 上了。到底是怎么回事呢?今天我们来聊一聊...