多线程之面试常考题——进程线程联系和区别(全面详解)【多线程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. 错误隔离

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

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

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


总结

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

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

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

相关推荐
做一个快乐的小傻瓜6 小时前
ZYNQ DEV套件引脚约束
java·linux·运维
CoderYanger7 小时前
Java EE:6.网络编程套接字(第二弹)
java·网络·程序人生·面试·职场和发展·java-ee·学习方法
devilnumber7 小时前
Java Lambda 表达式 200 条常见问题、坑点、易错点、规范清单
java·开发语言
xxwl5857 小时前
工作室小测的部分记录
c++·学习·算法
极客先躯7 小时前
高级java每日一道面试题-2026年02月12日-实战篇[Docker]-什么是容器的 Seccomp 配置?如何自定义?
java·运维·分布式·docker·容器·自动化·文件
大大杰哥7 小时前
Vue2学习(3)--组件中的通信方式/组件之间的交互
java·前端·javascript
zzz_23687 小时前
【Java基础】二叉树遍历与红黑树的完美平衡艺术——从递归崩溃到自平衡的硬核拆解
java·开发语言
智者知已应修善业7 小时前
【51单片机串口通信甲机四个按键模拟四位二进制值发送乙机以十进制显示2位数码管】2024-6-14
c++·经验分享·笔记·算法·51单片机
KobeSacre7 小时前
划分为k个相等的子集
算法·leetcode·深度优先
斯内普吖7 小时前
(开源)高校素拓分管理系统小程序实战指南 基于 Java + SpringBoot + uni-app + Vue + MySQL
java·spring boot·mysql·小程序·uni-app·开源