linux中多进程和多线程的区别是什么

发布时间 - 2022-01-11 00:00:00    点击率:
区别:1、多进程中数据共享复杂、同步简单,而多线程中数据共享简单、同步复杂;2、多进程占用内存多、切换复杂、速度慢、CPU利用率低,而多线程占用内存少、切换简单、CPU利用率高;3、多进程的编程简单、调试简单,而多线程的编程复杂、调试复杂。

本教程操作环境:linux5.9.8系统、Dell G3电脑。

linux中多进程和多线程的区别

进程:运行中(加载到内存上)的程序。-->执行过程称之为进程。

线程:线程是轻量级的进程,是进程中的一条执行序列(一组有序指令),一个进程至少有一条线程。

main函数所代表的执行序列称之为主线程。通过线程库创建的线程称之为函数线程。

对比维度 多进程 多线程 总结
数据共享,同步

数据共享复杂,需要用IPC;

数据是分开的,同步简单

因为共享进程数据,共享数据简单,同时导致同步也复杂 各有优势
内存、CPU 占用内存多,切换复杂,速度慢,CPU利用率低 占用内存少,切换简单CPU利用率高 多线程优势
创建销毁、切换 创建销毁,切换复杂,速度慢 创建销毁,切换简单,速度很快 多线程优势
编程调试 编程简单,调试简单 编程复杂,调试复杂 多进程优势
可靠性 进程间不会互相影响 一个线程挂掉将导致整个进程挂掉 多进程优势
分布式 适用于多核、多机分布式;如果一台机器不够,拓展到多台机器比较简单 适用于多核分布式 多进程优势

多线程的优点:

  • 无需跨进程边界;

  • 程序逻辑和控制方式简单;

  • 所有线程可以直接共享内存和变量;

  • 线程方式消耗的总资源比进程少

多进程的优点

  • 每个进程相互独立,不影响主程序的稳定性,子进程崩溃没关系;

  • 通过增加CPU就可以容易扩充性能;

  • 可以尽量减少线程加锁/解锁的影响,极大提高性能;

多线程的缺点: 

  • 每条线程与主程序共用地址空间,大小受限;

  • 线程之间的同步和加锁比较麻烦;

  • 一个线程的崩溃可能影响到整个程序的稳定性;

  • 到达一定的线程数后,即使在增加CPU也无法提高性能;

多进程的缺点: 

  • 逻辑控制复杂,需要和主程序交互;

  • 需要跨进程边界,如果有大数据传输,不适合;

  • 多进程调度开销比较大

应用情况如下:

1)需要频繁创建销毁的用线程

        这种原则最常见的就是Web服务器了,来一个连接建立一个线程,断了就销毁线程。如果用进程,创建销毁的代价是很难承受的。

2)需要进行大量计算的优先用线程

        所谓大量计算就是消耗很多CPU,切换频繁,这种情况下线程是最合适的。

        这种原则最常用的就是图像处理,算法处理。

3)强相关的处理用线程,弱相关的处理用进程

        什么叫强相关、弱相关?理论上很难定义,举一个例子加以解释。

        一般的Server需要完成如下任务:消息收发、消息处理。“消息收发”、“消息处理”就是弱相关的处理,而“消息处理”里面又分为“消息解码”、“业务处理”,这两个业务相对来说就强很多。因此“消息收发”、“消息处理”可以分进程设计,“消息解码”、“业务处理”可以分线程设计。

4)可能扩展到多机分布的用进程,多核分布的用线程(具体原因请看上表)

消耗资源:

        从内核的观点看,进程的目的就是担任分配系统资源(CPU时间、内存等)的基本单位。线程是进程的一条执行流,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。

        线程,他们之间使用相同的地址空间,共享大部分数据,启动一个线程所花费的空间远远小于启动一个进程所花费的空间,而且线程间彼此切换所需要的时间也远远小于进程间切换所用的时间。

通讯方式:

        进程间传递数据只能通过通讯的方式,既费时又不方便。线程时间数据大部分共享,快捷方便,但是数据同步需要锁。

线程自身优势:

        提高应用程序相应;使用CPU系统更加有效;操作系统会保证当线程数目不大于CPU数目时候,不同的线程运行在不同的CPU上;改善程序结构,一个即长又复杂的进程可以考虑分为多个线程,成为几个独立或者半独立的部分,这样的程序会易于理解和修改。

相关推荐:《Linux视频教程》


# linux  # 分布式  # 线程  # 多线程  # 主线程  # 算法  # 多核  # 主程序  # 用线  # 速度慢  # 很难  # 适用于  # 率高  # 称之为  # 加锁 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Collections进行数据处理?(实用方法示例)  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Laravel怎么清理缓存_Laravel optimize clear命令详解  如何实现javascript表单验证_正则表达式有哪些实用技巧  如何在橙子建站上传落地页?操作指南详解  Laravel如何创建自定义中间件?(Middleware代码示例)  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  详解Android——蓝牙技术 带你实现终端间数据传输  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  如何续费美橙建站之星域名及服务?  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  SQL查询语句优化的实用方法总结  如何在万网利用已有域名快速建站?  java ZXing生成二维码及条码实例分享  如何快速建站并高效导出源代码?  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  如何快速使用云服务器搭建个人网站?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何在云主机快速搭建网站站点?  Python制作简易注册登录系统  大连网站制作公司哪家好一点,大连买房网站哪个好?  jquery插件bootstrapValidator表单验证详解  Laravel如何发送系统通知?(Notification渠道示例)  Laravel用户密码怎么加密_Laravel Hash门面使用教程  在线教育网站制作平台,山西立德教育官网?  Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑  Laravel如何使用模型观察者?(Observer代码示例)  javascript读取文本节点方法小结  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  简单实现jsp分页  如何用搬瓦工VPS快速搭建个人网站?  微信h5制作网站有哪些,免费微信H5页面制作工具?  Laravel定时任务怎么设置_Laravel Crontab调度器配置  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  佛山企业网站制作公司有哪些,沟通100网上服务官网?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  phpredis提高消息队列的实时性方法(推荐)  公司网站制作需要多少钱,找人做公司网站需要多少钱?  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  魔方云NAT建站如何实现端口转发?  EditPlus中的正则表达式 实战(2)  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  如何快速配置高效服务器建站软件?  如何基于云服务器快速搭建网站及云盘系统?  Android使用GridView实现日历的简单功能