应该没有伪多线程,也不存在伪并发,而只存在伪并行,欢迎进行理性讨论

并发与并行的区别是什么?
并发的关键是你有处理多个任务的能力,不一定要同时。
并行的关键是你有同时处理多个任务的能力。
多线程可以说是并发而多进程可以说是并行。

并发与并行的区别是什么? - 知乎

并行必须多核CPU才能办到,并发单核就可以做到(并发宏观并行,微观串行)。
线程与进程,并发与并行区别

线程与进程,并发与并行区别_White Code的博客-CSDN博客_进程的并发和并行

进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进
程;进程也是程序的一次执行过程,是系统运行程序的基本单位;系统运行一个程序就是一个进程从创建,运行到
消亡的过程。
线程:线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少由一个线程。一个进程中是可
以由多个线程的,这个应用程序也可以称之为多线程程序。
Python 多线程居然是——假的?//写的很好
一:多线程写法可以让某些程序更好写,比如计算一个普通的顺序控制用多线程来写还需要“创建/切换”的时间代
价,这样运行成本会高,但如果要检索一个文本文件中的数据,为了提高检索效率,可以将文件分成小段的来处
理,最先在那段中找到了,就结束处理过程,这样运行成本会低。

二:处理阻塞型 I/O 任务效率更高
阻塞型 I/O 的意思是,当系统需要与文件系统(也包括网络和终端显示)交互时,由于文件系统相比于 CPU 的
处理速度慢得多,所以程序会被设置为阻塞状态,即,不再被分配计算资源。
而用多线程,当一个处理过程被阻塞之后,就会立即被 GIL 切走,将计算资源分配给其他可以执行的过程,从而
提示执行效率。
有了这两个特性,就说明 Python 的多线程并非一无是处,如果能根据情况编写好,效率会大大提高,只不过对
于计算密集型的任务,多线程特性爱莫能助。

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

进程和线程的调度是由操作系统自动完成。

进程:每个进程都有自己独立的内存空间,不同进程之间的内存空间不共享。

进程之间的通信有操作系统传递,导致通讯效率低,切换开销大。

线程:一个进程可以有多个线程,所有线程共享进程的内存空间,通讯效率高,切换开销小。

共享意味着竞争,导致数据不安全,为了保护内存空间的数据安全,引入"互斥锁"。

一个线程在访问内存空间的时候,其他线程不允许访问,必须等待之前的线程访问结束,才能使用这个内存空间。

互斥锁:一种安全有序的让多个线程访问内存空间的机制。

快速理解多进程与多线程以及协程的使用场合和特点_zlx_csdn的博客-CSDN博客_多线程和协程

为什么老说python是伪多线程,怎么解决?

为什么老说python是伪多线程,怎么解决?_melon0014的博客-CSDN博客_python伪多线程

Python的多线程不是真的多线程(GIL全局解释器锁)

Python的多线程不是真的多线程(GIL全局解释器锁)_hxxjxw的博客-CSDN博客_python多线程不是真正的多线程

        看了这么多大家写的资料,很多关于python是伪多线程的说法最后也只想表达不能真正的并行,本来多线程的说法通常也就是在一个进程下多个任务也就是多个线程的切换,从宏观来看像并行,微观来看是串行,首先搞懂线程进程并发并行的概念后,再去讨论这个问题,好像本来伪多线程的说法就是伪命题,本质上来看好像也只有的多进程才能对拥有真正的并行的概念,这是一个小小的思考,欢迎大家理性讨论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值