线程和进程 / 进程和线程的区别和联系

简介: 每个应用程序运行于现代操作系统之上时,操作系统会提供一种抽象,好像系统上只有这个程序在运行,所有的硬件资源都被这个程序在使用。这种假象是通过抽象了一个进程的概念来完成的,进程可以说是计算机科学中最重要和最成功的概念之一.

💖 欢迎来阅读子豪的博客(JavaEE篇 🤴)


👉 有宝贵的意见或建议可以在留言区留言


💻 欢迎 素质三连 点赞 关注 收藏


🧑‍🚀码云仓库:补集王子的代码仓库


472f1124c9b74654820a5f037782772c.gif


不要偷走我小火车哦~ ~ ~


💻进程(process)


每个应用程序运行于现代操作系统之上时,操作系统会提供一种抽象,好像系统上只有这个程序在运行,所有的硬件资源都被这个程序在使用。这种假象是通过抽象了一个进程的概念来完成的,进程可以说是计算机科学中最重要和最成功的概念之一.


简单来说进程指:在内存中运行的应用程序


进程是操作系统进行资源分配的最小最基本的单位


🎃进程的特点


进程中的一个执行任务(控制单元),负责当前进程中程序的执行。


如下图 IDEA和Edge就是进程


07c4effaa65d49e988966a7cadc34747.png


📢进程跟程序不一样


程序(Program)就是一组指令以及这组指令要处理的数据。狭义上来说,程序通常表现为一组文件


程序 = 指令 + 指令要处理的数据。


进程VS程序:


· 程序是在一个静态磁盘上的一个可执行文件。


· 进程是将可执行文件加载到系统中。加载就是将信息放在内存中,分配一些资源,并且执行程序中所有指令


内容主要有:


  • 进程编号 PID:进程的身份标识


  • 执行优先级


  • 上下文:保存本次执行状态,以便下次继续执行,这个过程就是一个上下文。


  • 内存地址


  • 进程的状态


🎯进程状态


①新建状态(NEW) ②就绪状态 ③运行状态 ④阻塞状态 ⑤销毁状态


1a7d29d4f44b410086b722c40d37cb83.png


📠线程(Thread)


一个线程就是一个 “执行流”. 每个线程之间都可以按照顺讯执行自己的代码. 多个线程之间 “同时” 执行着多份代码.


( ̄︶ ̄)↗ 多线程提高CPU使用率


线程是操作系统能够进行运算调度的最小单元。它被包含在进程中,是进程中实际运行的单位。一个进程中可以并发多个线程,每个线程执行不同的任务 。


一个线程 一辈子只能start一次**<( ̄︶ ̄)↗[GO!]**


2a49dbf0048c4636b671059d78e90a4d.png


系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为"轻量级进程"


🔦线程的特点


(1)"轻量"易于调度。


(2)提高并发性。通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。


(3)开销少。创建线程比创建进程要快,所需开销很少。


(4)利于充分发挥多处理器的功能。通过创建多线程进程,每个线程在一个处理器上运行,从而实现应用程序的并发性,使每个处理器都得到充分运行。(并发编程的核心!!!)


🚢进程 VS 线程


线程是进程的子任务,一个进程至少有一个线程,一个进程可以运行多个线程,多个线程可共享数据。进程中包含了线程,线程属于进程。集合与元素的关系


🛫区别


1.根本区别:进程是操作系统进行资源分配的最小单元,线程是操作系统进行运算调度的最小单元。


2.开销不同:进程的创建、销毁和切换的开销都远大于线程。每个进程都有独立的代码和数据空间(程序上下文,保存本次的执行状态,以便下次执行。),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。


3.拥有资源不同:每个进程有自己的内存和资源,一个进程中的线程会共享这些内存和资源。如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的,同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟机栈和本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多。


4.内存分配:同一进程的线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的


5.控制和影响能力不同:子进程无法影响父进程,而子线程可以影响父线程,如果主线程发生异常会影响其所在进程和子线程。


6.CPU利用率不同:进程的CPU利用率较低,因为上下文切换开销较大,而线程的CPU的利用率较高,上下文的切换速度快。


7.操纵者不同:进程的操纵者一般是操作系统,线程的操纵者一般是编程人员。


8.执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口。但是线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制,两者均可并发执行


💡Tips:堆和方法区


堆和方法区是所有线程共享的资源,其中堆是进程中最大的一块内存,主要用于存放新创建的对象 (所有对象都在这里分配内存),方法区主要用于存放已被加载的类信息、常量、静态变量、即时编译器编译后的代码等数据线程与进程不同的是同类的多个线程共享进程的堆和方法区资源


🧧多进程和多线程区别


多进程:操作系统中同时运行的多个程序,提高CPU使用率


多线程:在同一个进程中同时运行的多个任务


一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都挂掉。所以多进程要比多线程健壮。


多线程程序可以同时运行多个线程,但是程序运行的结果发现,每一次结果都不一致。 因为多线程存在一个特性:随机性。造成随机性的原因:CPU在瞬间不断切换去处理各个线程而导致的,可以理解成多个线程在抢CPU资源。(抢占式执行也是并发编程出错的罪魁祸首!!!)


3816cd85c9a441f6bfb5cc2289d3040d.png


多线程并不能提高运行速度,但可以提高运行效率,让CPU的使用率更高。但是如果多线程有安全问题或出现频繁的上下文切换时,运算速度可能反而更低。


虽然多进程也能实现并发编程,但是线程比进程更轻量


看到这里咯,点个**关注**再走!

相关文章
|
2月前
|
调度 开发者 Python
深入浅出操作系统:进程与线程的奥秘
在数字世界的底层,操作系统扮演着不可或缺的角色。它如同一位高效的管家,协调和控制着计算机硬件与软件资源。本文将拨开迷雾,深入探索操作系统中两个核心概念——进程与线程。我们将从它们的诞生谈起,逐步剖析它们的本质、区别以及如何影响我们日常使用的应用程序性能。通过简单的比喻,我们将理解这些看似抽象的概念,并学会如何在编程实践中高效利用进程与线程。准备好跟随我一起,揭开操作系统的神秘面纱,让我们的代码运行得更加流畅吧!
|
1月前
|
消息中间件 调度
如何区分进程、线程和协程?看这篇就够了!
本课程主要探讨操作系统中的进程、线程和协程的区别。进程是资源分配的基本单位,具有独立性和隔离性;线程是CPU调度的基本单位,轻量且共享资源,适合并发执行;协程更轻量,由程序自身调度,适合I/O密集型任务。通过学习这些概念,可以更好地理解和应用它们,以实现最优的性能和资源利用。
62 11
|
1月前
|
Java Linux 调度
硬核揭秘:线程与进程的底层原理,面试高分必备!
嘿,大家好!我是小米,29岁的技术爱好者。今天来聊聊线程和进程的区别。进程是操作系统中运行的程序实例,有独立内存空间;线程是进程内的最小执行单元,共享内存。创建进程开销大但更安全,线程轻量高效但易引发数据竞争。面试时可强调:进程是资源分配单位,线程是CPU调度单位。根据不同场景选择合适的并发模型,如高并发用线程池。希望这篇文章能帮你更好地理解并回答面试中的相关问题,祝你早日拿下心仪的offer!
39 6
|
2月前
|
消息中间件 Unix Linux
【C语言】进程和线程详解
在现代操作系统中,进程和线程是实现并发执行的两种主要方式。理解它们的区别和各自的应用场景对于编写高效的并发程序至关重要。
86 6
|
2月前
|
调度 开发者
深入理解:进程与线程的本质差异
在操作系统和计算机编程领域,进程和线程是两个核心概念。它们在程序执行和资源管理中扮演着至关重要的角色。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
81 5
|
2月前
|
算法 调度 开发者
深入理解操作系统:进程与线程的管理
在数字世界的复杂编织中,操作系统如同一位精明的指挥家,协调着每一个音符的奏响。本篇文章将带领读者穿越操作系统的幕后,探索进程与线程管理的奥秘。从进程的诞生到线程的舞蹈,我们将一起见证这场微观世界的华丽变奏。通过深入浅出的解释和生动的比喻,本文旨在揭示操作系统如何高效地处理多任务,确保系统的稳定性和效率。让我们一起跟随代码的步伐,走进操作系统的内心世界。
|
2月前
|
调度 开发者
核心概念解析:进程与线程的对比分析
在操作系统和计算机编程领域,进程和线程是两个基本而核心的概念。它们是程序执行和资源管理的基础,但它们之间存在显著的差异。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
82 4
|
7月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
7月前
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
220 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
|
6月前
|
算法 Linux 调度
探索进程调度:Linux内核中的完全公平调度器
【8月更文挑战第2天】在操作系统的心脏——内核中,进程调度算法扮演着至关重要的角色。本文将深入探讨Linux内核中的完全公平调度器(Completely Fair Scheduler, CFS),一个旨在提供公平时间分配给所有进程的调度器。我们将通过代码示例,理解CFS如何管理运行队列、选择下一个运行进程以及如何对实时负载进行响应。文章将揭示CFS的设计哲学,并展示其如何在现代多任务计算环境中实现高效的资源分配。

相关实验场景

更多