多进程和多线程的区别是什么?多进程和多线程的优缺点分析
发布时间:2022-10-27 01:40:36
多进程和多线程的区别是什么?此前小编给大家介绍了进程和线程的区别,那么大家知道多进程和多线程的区别又是什么吗?它们分别有什么优缺点?为了解决大家的疑惑,小编特地为大家整理了以下教程,希望对大家有所帮助。
前言:
多进程,Windows 应用程序中消息有两种送出途径;直接和排队。Windows或某些运行的应用程序可直接发布消息给窗口过程,或者,消息可送到消息列象连续不断轮询消息队列的OS中当前执行的每个进程都 事件驱动程序不是由事件的顺序来控制,而是由事件的发生来控,而事件的发生是随机的、不确定的,这就允许程序的用户用各种合理的顺序来安排程序的流程。
多线程(英语:multithreading),是指从软件或者硬件上实现多个线程并发执行的技术。具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程,进而提升整体处理性能。具有这种能力的系统包括对称多处理机、多核心处理器以及芯片级多处理(Chip-level multithreading)或同时多线程(Simultaneous multithreading)处理器。[1] 在一个程序中,这些独立运行的程序片段叫作“线程”(Thread),利用它编程的概念就叫作“多线程处理(Multithreading)”。具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程(台湾译作“执行绪”),进而提升整体处理性能。
一、多进程和多线程的区别是什么?
在Linux下编程多用多进程编程少用多线程编程。
IBM有个家伙做了个测试,发现切换线程context的时候,windows比linux快一倍多。进出最快的锁(windows2k的 critical section和linux的pthread_mutex),windows比linux的要快五倍左右。当然这并不是说linux不好,而且在经过实际编程之后,综合来看我觉得linux更适合做high performance server,不过在多线程这个具体的领域内,linux还是稍逊windows一点。这应该是情有可原的,毕竟unix家族都是从多进程过来的,而 windows从头就是多线程的。
如果是UNIX/linux环境,采用多线程没必要。
多线程比多进程性能高?误导!
应该说,多线程比多进程成本低,但性能更低。
在UNIX环境,多进程调度开销比多线程调度开销,没有显著区别,就是说,UNIX进程调度效率是很高的。内存消耗方面,二者只差全局数据区,现在内存都很便宜,服务器内存动辄若干G,根本不是问题。
多进程是立体交通系统,虽然造价高,上坡下坡多耗点油,但是不堵车。
多线程是平面交通系统,造价低,但红绿灯太多,老堵车。
我们现在都开跑车,油(主频)有的是,不怕上坡下坡,就怕堵车。
高性能交易服务器中间件,如TUXEDO,都是主张多进程的。实际测试表明,TUXEDO性能和并发效率是非常高的。TUXEDO是贝尔实验室的,与UNIX同宗,应该是对UNIX理解最为深刻的,他们的意见应该具有很大的参考意义。
二、多进程和多线程的优缺点分析:
多进程:
多进程优点:
1、每个进程互相独立,不影响主程序的稳定性,子进程崩溃没关系;
2、通过增加CPU,就可以容易扩充性能;
3、可以尽量减少线程加锁/解锁的影响,极大提高性能,就算是线程运行的模块算法效率低也没关系;
4、每个子进程都有2GB地址空间和相关资源,总体能够达到的性能上限非常大。
多进程缺点:
1、逻辑控制复杂,需要和主程序交互;
2、需要跨进程边界,如果有大数据量传送,就不太好,适合小数据量传送、密集运算 多进程调度开销比较大;
3、最好是多进程和多线程结合,即根据实际的需要,每个CPU开启一个子进程,这个子进程开启多线程可以为若干同类型的数据进行处理。当然你也可以利用多线程+多CPU+轮询方式来解决问题……
4、方法和手段是多样的,关键是自己看起来实现方便有能够满足要求,代价也合适。
多线程:
多线程的优点:
1、无需跨进程边界;
2、程序逻辑和控制方式简单;
3、所有线程可以直接共享内存和变量等;
4、线程方式消耗的总资源比进程方式好。
多线程缺点:
1、每个线程与主程序共用地址空间,受限于2GB地址空间;
2、线程之间的同步和加锁控制比较麻烦;
3、一个线程的崩溃可能影响到整个程序的稳定性;
4、到达一定的线程数程度后,即使再增加CPU也无法提高性能,例如Windows Server 2003,大约是1500个左右的线程数就快到极限了(线程堆栈设定为1M),如果设定线程堆栈为2M,还达不到1500个线程总数;
5、线程能够提高的总性能有限,而且线程多了之后,线程本身的调度也是一个麻烦事儿,需要消耗较多的CPU。
关于多进程和多线程的区别就给大家介绍到这里了,还蒙在鼓里的伙伴,赶紧看看以上教程吧!相信你会有所收获!


猜你喜欢
- 办公党们经常会做一些文件,而这些文件都是相当重要的,大多话费了我们很多的心血,所以我们必须保护我们的文件,无论是出于私密性还是安全性,我们都
- 在Word文档中以一个插入“公式”功能,如果有需要我们可以使用该功能在文档中插入一些公式以及一些公式的符号,非常地方便。我们还可以灵活使用该
- 战地5是一款第一人称的设计游戏,它的画面、音质效果都非常优秀,吸引了大量的玩家下载游戏。但是这些想要玩战地5游戏的用户们在打开游戏的时候,发
- 大家在使用winxp系统的时候经常使用一种开始菜单样式会感觉视觉疲劳,今天小编给大家带来一篇教程关于WinXP系统如何设置开始菜单样式,需要
- 利用任务管理器所查看的只是物理内存,如果想查看某软件或系统组件所占的虚拟内存,那就得借助其它方式,不过在win7中通过任务管理器并可轻松查看
- Windows 8兼容性中心检查软件和硬件的兼容性,如果无法找到所需程序,还可以通过以下几个方面来检测判断游戏与系统的兼容性,下面以“宝石迷
- 微软为Windows 7/8.1悄然推出KB3035583更新,其中的详细信息显示微软如何试图说服用户更新到Windows 10,下面我们一
- PPT怎么制作Win8风格的圆环形数据?Win8的圆形数据给我们眼前一亮的感觉,那么,我们接下来就学学如何设计制作这种圆形的数据,同时再教大
- Windows 10 Creators Update(创意者更新)RTM正式版——win10 Build 15063已经正式发布了,且win
- 大家都喜欢在电脑上玩游戏来打发时间,一般会选择全屏来玩游戏,游戏效果比较好。可是一些用户说在Win7 ghost系统中玩游戏,碰到了游戏屏幕
- Word Clock for Mac是目前很受欢迎的数字时钟屏保程序,通过突出显示来自30多种语言之一的适当单词来显示时间。选择线性或动态旋
- WinXP历经十几年时间,兼容大部分的应用和游戏,非常适合老机子安装,使用更稳定,运行更加快速。这里为大家带来了几款WinXP SP3纯净优
- HLOOKUP函数与VLOOKUP函数一样,都是根据指定行或列的值查找对应行或列的值,当进行垂直查找时用VLOOKUP函数,进行水平查找时用
- 在mac电脑上,如果使用谷歌浏览器,显示无法访问网络怎么办?不能访问网络是由于你电脑设置了网络权限,为浏览器赋予访问网络的权限就可以了。1.
- word怎么设计一款漂亮的发展历程的流程图?公司发展肯定格式有些年限的,想要根据时间来设计一个发展历程,该怎么设计呢?下面我们就来看看详细的
- 钉钉圈子怎么删除动态?这篇文章主要介绍了钉钉圈子删除动态教程,需要的朋友可以参考下有时候我们在使用钉钉圈子的时候,想删除动态,怎么删除呢,下
- 以WPS 2019版为例,选中数据区域,点击“数据”--->“分列”。 在弹出的界面中点击“固定宽度”,然后根据
- 在Win7操作系统中,有一个帮助和支持功能,这个功能可以在我们遇到一些问题的时候,来帮助我们进行解决。比如怎么关闭UAC等,在帮助和支持里都
- Excel表格中开根号方法有多种。这里介绍一种笔者常用的,那就是在函数栏输入“=(数值或表达式)^(1/开方数)”,实操如下:1、新建一个E
- Word现在已经成为我们工作和日常生活中必不可少的工具,那么在word文档中如何快速添加出自己需要的下划线呢?小编给大家支支招:一、最简单的