【Java面试题】多进程及多线程的区别?

线程与进程的区别如下:

  1. 进程是资源分配的最小单位,线程是资源调度的最小单位。
  2. 线程是在进程下运行的。一个进程可以包含多个线程。
  3. 进程有自己的独立地址空间,每启动一个进程,系统就会为它分配地址空间。而线程是共享进程中的数据的,使用相同的地址空间。
  4. 同一进程下不同线程间数据容易共享,不同进程间数据很难共享。
  5. 线程之间没有单独的地址空间,一个线程死掉,整个进程也死掉。而一个进程死掉并不会对另外一个进程造成影响。
区别 进程 线程
根本区别 作为资源分配的单位 调度和执行的单位
开销 每个进程都有独立的代码和数据空间(进程上下文),进程间的切换开销大 同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器PC,线程的切换开销小(部分寄存器)
所处环境 OS中能同时运行多个任务/程序 同一个应用程序中有多个顺序流同时执行
分配内存 系统在运行时会为每个进程分配不同的内存区域 除了CPU外,不会为线程分配内存,只能共享那个所在线程的资源,拥有相同的地址空间
包含关系 没有线程的进程可以被视为单线程的,如果一个进程拥有多个线程,则执行过程不是一条直线的,而是多条线共同完成 线程是进程的一部分,所以线程被称为轻权或轻量级进程

多线程的优点:

  • 无需跨进程边界;

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

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

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

多进程的优点

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

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

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

多线程的缺点

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

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

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

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

多进程的缺点:

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

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

  • 多进程调度开销比较大

相关推荐
Absurd5871 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
2301_815279522 小时前
SQL如何利用聚合函数生成业务分析指标_KPI计算基础教程
jvm·数据库·python
小江的记录本2 小时前
【分布式】分布式核心组件——分布式锁:Redis/ZooKeeper/etcd 实现方案(附全方位对比表)、优缺点、Redlock、时钟回拨问题
java·网络·redis·分布式·后端·zookeeper·架构
qq_330037992 小时前
mysql如何排查Out of memory错误_mysql内存分配调优
jvm·数据库·python
好家伙VCC2 小时前
**发散创新:用Rust实现基于RAFT共识算法的轻量级分布式日志系统**在分布式系统中,**一致性协议**是保障数据可靠
java·分布式·python·rust·共识算法
weixin_458580123 小时前
如何在 Go 中直接将 AST 编译为可执行二进制文件?
jvm·数据库·python
晔子yy3 小时前
【JAVA探索之路】从头开始讲透、实现单例模式
java·开发语言·单例模式
阿正的梦工坊8 小时前
JavaScript 微任务与宏任务完全指南
开发语言·javascript·ecmascript
2301_816660218 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
第一程序员8 小时前
数据工程 pipelines 实践
python·github