操作系统知识点-进程与线程,一文搞懂!

news2025/1/11 23:03:22

 本文图片均来自王道考研

一、进程的概念、组成和特征

进程(Process)是计算机中的一个核心概念,它是对正在运行的程序的一个抽象表示。在计算机科学中,一个进程是系统进行资源分配和调度的一个独立单元,是操作系统结构的基础。简而言之,进程是操作系统进行资源管理的最小单位,是系统进行并发执行的基本单位,是独立运行的程序实体。

进程包含了运行一个程序所需的所有信息,包括程序代码、当前执行到哪条指令、程序运行时的数据(变量)、系统状态(如打开的文件、内存信息等)以及进程控制块(PCB,Process Control Block)等。PCB是操作系统用于记录进程状态的重要数据结构,它包含了进程的各种信息,如进程标识符(PID)、进程状态(就绪、运行、阻塞等)、程序计数器、CPU寄存器、内存管理信息、输入输出状态信息、会计信息(如CPU时间、实际使用时间等)等。

进程的特性

  1. 动态性:进程是程序的一次执行过程,是动态产生、变化和消亡的。
  2. 并发性:多个进程可以在一段时间内同时运行,但它们的逻辑上是独立的。
  3. 独立性:进程是系统进行资源分配和调度的独立单元,每个进程都拥有自己独立的地址空间。
  4. 异步性:进程按各自独立的、不可预知的速度向前推进,操作系统负责进程间的同步和通信。
  5. 结构性:进程由程序、数据和PCB三部分组成。

进程与程序的区别

  • 程序是静态的,是存储在硬盘上的可执行的二进制代码;进程是动态的,是程序执行的过程,包括动态创建、调度和消亡。
  • 同一个程序可以产生多个进程,进程是程序的一次执行实例。
  • 进程是系统进行资源分配和调度的独立单元,每个进程都有独立的内存空间和系统资源。

进程的状态

进程在其生命周期中会经历多种状态,常见的进程状态包括:

  • 新建(New):进程正在被创建。
  • 就绪(Ready):进程已准备好,等待CPU分配。
  • 运行(Running):进程正在CPU上执行。
  • 阻塞(Blocked):进程因为等待某个事件发生(如I/O操作)而暂停执行。
  • 终止(Terminated):进程已完成执行或被系统终止。

二、进程的状态与转换

三、进程控制

四、进程通信(IPC)

五、线程概念、多线程模型

线程是计算机科学中的一个基本概念,指的是在一个进程中执行的独立指令流。它是程序执行的最小单位,是进程的一个实体,也是系统独立调度和分派的基本单位。具体来说,线程具有以下特点:

定义与基本属性

  • 定义:线程是进程中负责执行的具体任务,即进程内部的执行序列或执行路线。
  • 资源共享:线程之间共享进程的代码段、数据段、堆、环境变量表、命令行参数、文件描述符、信号处理方式等资源(除了栈之外),这使得线程之间的数据交换和通信更为直接和高效。
  • 独立执行:虽然线程共享进程的资源,但每个线程都有自己独立的线程ID、寄存器信息、函数栈、错误码等,可以独立执行不同的任务。

线程与进程的关系

  • 进程是资源分配的最小单位:每个进程都拥有独立的虚拟地址空间,用于存储程序代码和数据。
  • 线程是调度的最小单位:操作系统通过线程来分配CPU时间片,实现任务的并发执行。一个进程可以包含多个线程,这些线程在进程内部并发执行,共享进程的资源。

线程的状态与操作

  • 线程状态:线程在其生命周期中会经历多种状态,如新建、就绪、运行、阻塞和终止等。系统通过管理线程的状态来实现线程的调度和同步。
  • 线程操作:系统提供了多种线程控制原语,如创建线程、取消线程、销毁线程等。程序员可以通过这些操作来创建和管理线程,实现复杂的并发编程任务。

线程的优势与挑战

  • 优势:线程能够提高程序的响应性和并发性,充分利用多核处理器的计算能力。同时,由于线程之间共享进程的资源,因此可以减少数据复制和传输的开销,提高程序的执行效率。
  • 挑战:多线程编程也带来了一些挑战,如竞态条件、死锁等问题。这些问题可能导致程序出现错误或不稳定的行为。因此,在设计和实现多线程程序时,需要仔细考虑线程之间的同步和互斥机制,以确保程序的正确性和稳定性。

六、线程的实现方式、多线程模型

七、线程的状态与转换

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2137829.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python数据分析 Pandas基本操作

Python数据分析 Pandas基本操作 一、Series基础操作 ​ Series是pandas的基础数据结构,它可以用来创建一个带索引的一维数组,下面开始介绍它的基础操作 1、创建Series 1)使用数据创建Series: import pandas as pd pd.Series(1…

学习笔记JVM篇(三)

一、垃圾回收机制 垃圾回收(Garbage Collection)机制,是自动回收无用对象从而释放内存的一种机制。Java之所以相对简单,很大程度是归功于垃圾回收机制。(例如C语言申请内存后要手动的释放) 优点&#xff…

基于less和scss 循环生成css

效果 一、less代码 复制代码 item-count: 12; // 生成多少个 .item 类.item-loop(n) when (n > 0) {.icon{n} {background: url(../../assets/images/menu/icon{n}.png) no-repeat;background-size: 100% 100%;}.item-loop(n - 1);}.item-loop(item-count);二、scss代码 f…

在线查看 Android 系统源代码 Android Code Search

在线查看 Android 系统源代码 Android Code Search 1. Android Code Search2. Android2.1. platform/superproject2.2. build/envsetup.sh2.3. build/make/envsetup.sh References 1. Android Code Search https://cs.android.com/ Android https://cs.android.com/android An…

PCIe进阶之TL:Address Spaces, Transaction Types, and Usage

1 Transaction Layer Overview 如上图为PCIe设备的一个分层结构,从上层逻辑看,事务层的关键点是: 流水线式的完整的 split-transaction 协议事务层数据包(TLP)的排序和处理基于信用的流控制机制可选支持的数据中毒功能和端到端数据完整性检测功能事务层包含以下内容: TLP…

【C++】标准库IO查漏补缺

【C】标准库 IO 查漏补缺 文章目录 系统I/O1. 概述2. cout 与 cerr3. cerr 和 clog4. 缓冲区5. 与 printf 的比较 系统I/O 1. 概述 标准库提供的 IO 接口,包含在 iostream 文件中 输入流: cin输出流:cout / cerr / clog。 输入流只有一个 cin&#x…

MFC工控项目实例之十六输入信号验证

承接专栏《MFC工控项目实例之十五定时刷新PC6325A模拟量输入》 验证选定的输入信号实时状态 在BoardTest.cpp文件中添加代码 void CBoardTest::OnButton2() {// TODO: Add your control notification handler code hereisThreadBegin true; //运行线程执行pThre…

medium_socnet

0x00前言 靶场要安装在virtualbox (最新版)。否者会出现一些问题。 攻击机:kali2024 靶机:medium_socnet 0x01信息搜集 因为把靶机和虚拟机啊放在了同一网段。 所以我先使用了 arp-scan,查看有多少同一网段ipUP 。 经过推断…

OSS对象资源管理

1、登录aliyun 1.1、什么是OSS?有什么用? OSS 是“Object Storage Service”的缩写,中文常称为“对象存储服务”。OSS 是一种互联网云存储服务,主要用于海量数据的存储与管理。 相较于nginx,OSS更灵活,不…

点云深度学习系列:Sam2Point——基于提示的点云分割

文章:SAM2POINT:Segment Any 3D as Videos in Zero-shot and Promptable Manners 代码:https://github.com/ZiyuGuo99/SAM2Point Demo:https://huggingface.co/spaces/ZiyuG/SAM2Point 1)摘要 文章介绍了SAM2POINT,这是…

跟《经济学人》学英文:2024年09月14日这期 People are splurging like never before on their pets

People are splurging like never before on their pets Would you buy your furry companion a cologne? like never before:从未有过;未曾发生过 splurge:挥霍;浪费;破费;大量花费;过度消…

python 读取excel数据存储到mysql

一、安装依赖 pip install mysql-connector-python 二、mysql添加表students CREATE TABLE students (ID int(11) NOT NULL AUTO_INCREMENT,Name varchar(50) DEFAULT NULL,Sex varchar(50) DEFAULT NULL,PRIMARY KEY (ID) ) ENGINEInnoDB AUTO_INCREMENT13 DEFAULT CHARSETu…

S32K3 工具篇5:如何使用lauterbach下载调试elf文件

S32K3 工具篇5:如何使用lauterbach下载调试elf文件 一,利用trace32现有flash脚本烧录elf二,debug 现有elf文件 之前写过如何在S32DS中使用lauterbach下载,但是对于RTD EB MCAL的代码,通常情况下是使用命令的方式去编译…

Spring Boot母婴商城:安全、便捷、高效

2 相关技术 2.1 SSM框架介绍 本课题程序开发使用到的框架技术,英文名称缩写是SSM,在JavaWeb开发中使用的流行框架有SSH、SSM、SpringMVC等,作为一个课题程序采用SSH框架也可以,SSM框架也可以,SpringMVC也可以。SSH框架…

C语言 | Leetcode C语言题解之第399题除法求值

题目: 题解: /*** Note: The returned array must be malloced, assume caller calls free().*/typedef struct hash_node_t {char *key;double val;int distinguish_flag; // 用于区分不同的关系struct hash_node_t *p_next; }HASH_NODE_T;typedef str…

clip论文阅读(Learning Transferable Visual Models From Natural Language Supervision)

目录 摘要训练pre-train model的过程将pre-train model应用于下游任务应用(待更新) 论文/项目地址:https://github.com/OpenAI/CLIP 提供了clip的pre-trained model的权重,也可安装使用pre-trained model 摘要 使用标签标注的图…

【IEEEACM Fellow、CCF组委】第三届人工智能与智能信息处理国际学术会议(AIIIP 2024)

第三届人工智能与智能信息处理国际学术会议(AIIIP 2024) 2024 3rd International Conference on Artificial Intelligence and Intelligent Information Processing 中国-天津 | 2024年10月25-27日 | 会议官网:www.aiiip.net 会…

【CTF MISC】XCTF GFSJ1086 [简单] 简单的base编码 Writeup(Base64编码+循环解码+Base92编码)

[简单] 简单的base编码 你懂base编码吗? 工具 在线BASE92编码解码:https://ctf.bugku.com/tool/base92 解法 Vm0wd2QyUXlVWGxWV0d4V1YwZDRWMVl3WkRSV01WbDNXa1JTVjAxV2JETlhhMUpUVmpBeFYySkVUbGhoTVVwVVZtcEJlRll5U2tWVWJHaG9UVlZ3VlZadGNFSmxSbGw1V…

数据集 wider person 户外密集行人检测 >> DataBall

数据集 wider person 用于野外密集行人检测的多样化数据集 行人检测 目标检测 户外密集行人检测的多样化数据集 WiderPerson: A Diverse Dataset for Dense Pedestrian Detection in the Wild article{zhang2019widerperson, Author {Zhang, Shifeng and Xie, Yiliang and Wa…

蛋白质结构变换中的四元数和旋转矩阵介绍

在蛋白质结构变换中,四元数和旋转矩阵都是用来描述旋转的重要工具。 一、旋转矩阵 定义与形式: 旋转矩阵是一个 33 的矩阵,用于将一个向量在三维空间中进行旋转操作。它可以表示为:其中,每个元素都是实数,且满足一定的正交性条件,即旋转矩阵的逆等于它的转置。作用原理…