进程与线程的关系,进程调度的基本过程

简介: 进程是操作系统分配资源的基本单位,每个进程都有自己的内存空间,独立分配的CPU时间片,以及其他系统资源。线程共享所属进程的资源,它们通常更轻量级,创建和切换线程的开销较小。

目标:


1. 了解进程与线程的关系


2. 进程调度的基本过程


进程与线程的关系

在我们学习进程调度前,我们先了解一下进程与线程:


1.进程是线程的容器

进程包含线程,一个进程里可以有一个线程,也可以有多个线程。


多个线程可以在同一个进程内共享进程的资源,如内存和文件,以实现并发执行。


2.资源分配

进程是操作系统分配资源的基本单位,每个进程都有自己的内存空间,独立分配的CPU时间片,以及其他系统资源。


线程共享所属进程的资源,它们通常更轻量级,创建和切换线程的开销较小。


3.并发性

进程和线程都可以用于实现并发性!!!


多个进程可以在不同的地址空间中并发执行,而多个线程共享相同的地址空间。(可以更容易地共享数据和协同工作)


4.独立性

进程是相互独立的,一个进程挂掉不会影响其他进程。


线程的崩溃会影响同一进程下的其他线程。


进程调度的基本过程

1.进程或线程创建

进程通过创建不同的 java 虚拟机实际来实现,线程通过"java.lang.Thread" 类创建。


2.资源分配

java 虚拟机管理线程和和进程的资源分配(cpu时间片,内存,其他系统资源)。


每个线程堆栈和程序计数器(共享相同的堆内存)。


3.线程调度

确定哪个线程应该在CPU上执行(java虚拟机线程调度器)


4.线程状态

就绪状态:线程已准备好执行


运行状态:线程正在执行


阻塞状态:线程被阻止等待某些条件


终止状态:线程已完成执行


5.调度策略

决定哪个线程应该执行(java虚拟机线程调度器)


6.线程同步

java中提供同步机制:锁,条件变量,确保多个线程之间的正确协调和共享资源的安全访问。这有助于避免竞态条件和死锁等问题(后面我会再整理死锁问题)。


7.线程终止

当线程完成其任务或出现异常时,它将进入终止状态。(可以正常终止或被强制终止)


目录
打赏
0
0
0
0
1
分享
相关文章
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
深入浅出操作系统:进程与线程的奥秘
在数字世界的底层,操作系统扮演着不可或缺的角色。它如同一位高效的管家,协调和控制着计算机硬件与软件资源。本文将拨开迷雾,深入探索操作系统中两个核心概念——进程与线程。我们将从它们的诞生谈起,逐步剖析它们的本质、区别以及如何影响我们日常使用的应用程序性能。通过简单的比喻,我们将理解这些看似抽象的概念,并学会如何在编程实践中高效利用进程与线程。准备好跟随我一起,揭开操作系统的神秘面纱,让我们的代码运行得更加流畅吧!
Java线程调度揭秘:从算法到策略,让你面试稳赢!
在社招面试中,关于线程调度和同步的相关问题常常让人感到棘手。今天,我们将深入解析Java中的线程调度算法、调度策略,探讨线程调度器、时间分片的工作原理,并带你了解常见的线程同步方法。让我们一起破解这些面试难题,提升你的Java并发编程技能!
113 16
Python实用技巧:轻松驾驭多线程与多进程,加速任务执行
在Python编程中,多线程和多进程是提升程序效率的关键工具。多线程适用于I/O密集型任务,如文件读写、网络请求;多进程则适合CPU密集型任务,如科学计算、图像处理。本文详细介绍这两种并发编程方式的基本用法及应用场景,并通过实例代码展示如何使用threading、multiprocessing模块及线程池、进程池来优化程序性能。结合实际案例,帮助读者掌握并发编程技巧,提高程序执行速度和资源利用率。
37 0
如何区分进程、线程和协程?看这篇就够了!
本课程主要探讨操作系统中的进程、线程和协程的区别。进程是资源分配的基本单位,具有独立性和隔离性;线程是CPU调度的基本单位,轻量且共享资源,适合并发执行;协程更轻量,由程序自身调度,适合I/O密集型任务。通过学习这些概念,可以更好地理解和应用它们,以实现最优的性能和资源利用。
92 11
硬核揭秘:线程与进程的底层原理,面试高分必备!
嘿,大家好!我是小米,29岁的技术爱好者。今天来聊聊线程和进程的区别。进程是操作系统中运行的程序实例,有独立内存空间;线程是进程内的最小执行单元,共享内存。创建进程开销大但更安全,线程轻量高效但易引发数据竞争。面试时可强调:进程是资源分配单位,线程是CPU调度单位。根据不同场景选择合适的并发模型,如高并发用线程池。希望这篇文章能帮你更好地理解并回答面试中的相关问题,祝你早日拿下心仪的offer!
54 6
【C语言】进程和线程详解
在现代操作系统中,进程和线程是实现并发执行的两种主要方式。理解它们的区别和各自的应用场景对于编写高效的并发程序至关重要。
117 6
|
3月前
|
深入理解:进程与线程的本质差异
在操作系统和计算机编程领域,进程和线程是两个核心概念。它们在程序执行和资源管理中扮演着至关重要的角色。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
135 5
深入理解操作系统:进程调度的奥秘
在数字世界的心脏跳动着的是操作系统,它如同一个无形的指挥官,协调着每一个程序和进程。本文将揭开操作系统中进程调度的神秘面纱,带你领略时间片轮转、优先级调度等策略背后的智慧。从理论到实践,我们将一起探索如何通过代码示例来模拟简单的进程调度,从而更深刻地理解这一核心机制。准备好跟随我的步伐,一起走进操作系统的世界吧!

热门文章

最新文章

相关实验场景

更多