多线程之面试常考题——进程线程联系和区别(全面详解)【多线程0】

🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇

进程线程的紧密联系

🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇🎇

今日推荐歌曲: death bed (coffee for your head ) -- Powfu / beabadoobee 🎵🎵


目录

[1. 定义](#1. 定义)

[2. 资源分配](#2. 资源分配)

3.并发性

[4. 切换开销](#4. 切换开销)

[5. 通信机制](#5. 通信机制)

[6. 错误隔离](#6. 错误隔离)

总结


进程和线程是操作系统中管理和执行任务的两个重要概念,它们有着以下区别和联系:

1. 定义

进程(Process):是程序在执行过程中分配和管理资源的基本单位。每个进程都有独立的地址空间、内存和系统资源。

进程主要描述的是个⼈业务,即⼀个⼈完全处理⾃⼰的业 务。

线程(Thread):是进程中的一个执行单元,是CPU调度的基本单位。线程共享进程的地址空间和系统资源,但拥有独立的执行栈和程序计数器。

⼀家公司要去银⾏办理业务,既要进⾏财务转账,⼜要进⾏福利发放,还得进⾏缴社保。 如果只有张三⼀个会计就会忙不过来,耗费的时间特别⻓。为了让业务更快的办理好,张三⼜找来两 位同事李四、王五⼀起来帮助他,三个⼈分别负责⼀个事情,分别申请⼀个号码进⾏排队,⾃此就有 了三个执⾏流共同完成任务,但本质上他们都是为了办理⼀家公司的业务。 此时,我们就把这种情况称为多线程,将⼀个⼤任务分解成不同⼩任务,交给不同执⾏流就分别排队 执⾏。其中李四、王五都是张三叫来的,所以张三⼀般被称为主线程(MainThread)。

进程是包含线程的.每个进程⾄少有⼀个线程存在,即主线程。


2. 资源分配

  • 进程独立拥有系统资源,如内存空间、文件句柄等,每个进程有自己的资源集合。
  • 线程共享所属进程的资源,如内存空间、打开的文件等,但拥有独立的执行栈和程序计数器

⽐如之前的多进程例⼦中,每个客⼾来银⾏办理各⾃的业务,但他们之间的票据肯定是不想让别⼈知 道的,否则钱不就被其他⼈取⾛了么。⽽上⾯我们的公司业务中,张三、李四、王五虽然是不同的执 ⾏流,但因为办理的都是⼀家公司的业务,所以票据是共享着的。这个就是多线程和多进程的最⼤区 别。

进程和进程之间不共享内存空间.同⼀个进程的线程之间共享同⼀个内存空间.


3.并发性

进程是系统中独立的执行单位 ,多个进程可以并发执行,彼此之间相互独立

线程是进程中的实际执行单元 ,一个进程可以拥有多个线程,这些线程可以并发执行,共享进程的资源。


4. 切换开销

进程切换开销较大,因为需要切换地址空间和系统资源。

线程切换开销较小,因为线程共享进程的资源,切换时只需保存和恢复线程的执行栈和程序计数器。


5. 通信机制

进程间通信需要使用特定的通信机制,如管道、消息队列、共享内存等。

线程间通信更加直接,可以通过共享内存等方式进行通信。


6. 错误隔离

进程间相互独立,一个进程的错误不会影响其他进程。

线程共享进程的资源,一个线程的错误可能会影响到其他线程以及整个进程的稳定性。

⼀个进程挂了⼀般不会影响到其他进程.但是⼀个线程挂了,可能把同进程内的其他线程⼀起带⾛(整 个进程崩溃).


总结

在实际应用中,进程和线程往往会结合使用,利用进程间的独立性和线程间的共享特性,来提高系统的并发性和效率。

真嘟超级详细,都是手敲的 ,希望能帮助大伙,博客不易,

点赞 收藏 加关注,知识进脑不迷路!!!

相关推荐
秋说27 分钟前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy39 分钟前
力扣61.旋转链表
算法·leetcode·链表
一只叫煤球的猫1 小时前
【🤣离谱整活】我写了一篇程序员掉进 Java 异世界的短篇小说
java·后端·程序员
斐波娜娜1 小时前
Maven详解
java·开发语言·maven
Bug退退退1231 小时前
RabbitMQ 高级特性之事务
java·分布式·spring·rabbitmq
程序员秘密基地1 小时前
基于html,css,vue,vscode,idea,,java,springboot,mysql数据库,在线旅游,景点管理系统
java·spring boot·mysql·spring·web3
皮皮林5511 小时前
自从用了CheckStyle插件,代码写的越来越规范了....
java
小码氓1 小时前
Java填充Word模板
java·开发语言·spring·word
会飞的天明1 小时前
Java 导出word 实现饼状图导出--可编辑数据
java·word
Muxiyale1 小时前
使用spring发送邮件,部署ECS服务器
java·服务器·spring