python中多线程与多进程的区别和联系

python多线程实现
python多线程和多进程的区别
python多线程爬虫
python多线程坑
python多线程可以在windows下实现吗
python多线程并发
python多线程变量共享
python多线程是并发还是并行
python多线程实例
python多线程condition

Python中多进程与多线程的区别有:线程需要在进程中执行,一个进程可包含多个线程;进程可共享同个地址空间而进程共享物理地址,线程创建简单,进程需要对父进程克隆等等

今天将要分享的是Python中多进程与多线程的相关知识及区别,接下来将在文章中具体介绍,具有一定的参考价值,希望对大家有所帮助

更多的详细内容学习点我

【推荐课程:Python教程

线程的概念:

线程是操作系统中进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程可以有多个线程,每条线程可以同时执行不同的任务。一个线程可以看作一个cpu执行时所需要的一串指令

多线程

在Python的标准库中提供了两个模块:_thread和threading,_thread是低级模块不支持守护线程,当主线程退出时,所有子线程都会被强行退出。而threading是高级模块,用于对_thread进行了封装支持守护线程。在大多数情况下我们只需要使用threading这个高级模块即可。

进程的概念:

进程指的是一个程序在给定数据集合上的一次执行过程,是系统进行资源分配和运行调用的独立单位。也就是每一个应用程序都有一个自己的进程。进程在启动时都会最先产生一个线程,这个线程被称为主线程,然后再有主线程创建其他子线程

多进程:

多进程是multiprocessing模块提供远程与本地的并发,在一个multiprocessing库的使用场景下,所有的子进程都是由一个父进程启动来的,这个父进程成为madter进程,它会管理一系列的对象状态,一旦这个进程退出,子进程很可能处于一个不稳定的状态,所以这个父进程尽量要少做事来保持其稳定性

线程与进程的区别

(1)线程必须在某个进程中执行。一个进程可包含多个线程,并且只有一个主线程。

(2)多线程共享同个地址空间、打开的文件以及其他资源。而多进程共享物理内存、磁盘、打印机以及其他资源。

(3)线程几乎不占资源,系统开销少,切换速度快,而且同个进程中的多个线程可以实现数据共享,而进程之间是不可共享的

(4)新线程的创建很简单而新进程的创建需要对父进程进行克隆

(5)一个线程可以控制和操作同一进程里的其他线程;但是进程只能操作子进程

总结:以上就是本篇文章的全部内容了,希望对大家有所帮助。

以上就是python中多线程与多进程的区别的详细内容

个人一直觉得对学习任何知识而言,概念是相当重要的。掌握了概念和原理,细节可以留给实践去推敲。掌握的关键在于理解,通过具体的实例和实际操作来感性的体会概念和原理可以起到很好的效果。本文通过一些具体的例子简单介绍一下python的多线程和多进程,后续会写一些进程通信和线程通信的一些文章。

python多线程

python中提供两个标准库thread和threading用于对线程的支持,python3中已放弃对前者的支持,后者是一种更高层次封装的线程库,接下来均以后者为例。

创建线程

python中有两种方式实现线程:

1.实例化一个threading.Thread的对象,并传入一个初始化函数对象(initial function )作为线程执行的入口;

2.继承threading.Thread,并重写run函数;

方式1:创建threading.Thread对象

?

1

2

3

4

5

6

7

8

9

10

11

import threading

import time

def tstart(arg):

 time.sleep(0.5)

 print("%s running...." % arg)

if __name__ == '__main__':

 t1 = threading.Thread(target=tstart, args=('This is thread 1',))

 t2 = threading.Thread(target=tstart, args=('This is thread 2',))

 t1.start()

 t2.start()

 print("This is main function")

结果:

?更多的详细内容学习点我​​​​​​​

1

2

3

This is main function

This is thread 2 running....

This is thread 1 running....

方式2:继承threading.Thread,并重写run

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

import threading

import time

class CustomThread(threading.Thread):

 def __init__(self, thread_name):

  # step 1: call base __init__ function

  super(CustomThread, self).__init__(name=thread_name)

  self._tname = thread_name

 def run(self):

  # step 2: overide run function</

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值