计算机操作系统之并行性与并发性笔记

目录

在计算机操作系统中,并行性与并发性是两个既相似又有区别的重要概念

并行性:

并发性:

可以通过多任务处理和资源共享来具体说明

并发性的例子

并行性的例子

总结


在计算机操作系统中,并行性与并发性是两个既相似又有区别的重要概念

并行性:

它指的是两个或多个事件在同一时刻发生。

这意味着,如果有足够的处理单元(如多核CPU或分布式系统中的多个节点),这些事件可以真正地同时执行,互不干扰。并行性强调的是物理上的同时性,能够显著提高性能,因为多个任务可以同时进行,减少了总体完成时间。

并发性:

它则是指两个或多个事件在同一时间间隔内发生。

虽然从宏观上看,这些事件似乎是在同时运行,但实际上在单核或多核CPU的某一瞬间,通常只能有一道程序执行,各道程序轮流交替地执行。并发性强调的是逻辑上的同时性,通过操作系统的任务调度和时间片轮转等技术,使多个任务交替执行,从而提高了系统的吞吐量和资源利用率。然而,每个任务的实际执行可能并不是连续的,因此可能会引入一些额外的开销,如上下文切换等。

并行性和并发性都是计算机系统中处理多任务的重要策略,但它们在实现方式、效率、性能以及所需资源方面有所不同。选择使用并行性还是并发性,通常取决于具体的应用场景、硬件条件以及性能需求。

可以通过多任务处理和资源共享来具体说明

并发性的例子

在计算机操作系统中,并发性通常体现在单个处理器上通过时间片轮转来同时处理多个任务。假设你正在使用一台个人电脑,同时运行着以下几个程序:

文字处理软件(如Word):你正在编写一篇文章。

网页浏览器:多个标签页同时打开,其中一个在播放在线视频,另一个在浏览新闻。

音乐播放器:在后台播放你喜欢的音乐列表。

尽管从宏观上看,这些程序似乎都在同时运行,但实际上,由于你的电脑只有一个处理器(或多个处理器但操作系统可能将它们视为一个统一的资源池来管理任务),这些程序是通过操作系统的任务调度机制交替执行的。操作系统为每个程序分配一定的时间片,在这个时间片内,程序可以执行其指令。当时间片用完时,程序会被挂起,操作系统将CPU控制权交给另一个程序。由于这个时间片的切换非常快,用户通常不会感觉到程序是在交替执行的。

并行性的例子

并行性在计算机系统中则更多地体现在多处理器或多核处理器环境中。假设你所在的实验室拥有一台高性能计算集群,该集群由多个节点组成,每个节点都有多个处理器核心。在这样的系统中,并行性可以得到充分的利用。

科学计算任务:研究人员提交了一个复杂的物理模拟任务,该任务被分解为多个较小的子任务,每个子任务都可以独立地在集群的一个或多个节点上并行执行。这些子任务之间可能通过消息传递接口(MPI)或其他并行通信机制来交换数据。

数据库查询:在一个大型数据库中,多个查询请求可以同时提交给数据库管理系统。数据库管理系统可以利用并行查询处理技术来同时处理这些查询请求,每个请求可能在不同的处理器核心上并行执行其计算密集型部分,如连接操作、排序操作等。

总结

在计算机操作系统中,并发性允许单个处理器上通过时间片轮转来同时处理多个任务,从而提高系统的吞吐量和资源利用率。而并行性则利用多处理器或多核处理器的计算能力来真正地同时执行多个任务,从而提高系统的整体性能。这两个概念都是现代计算机系统中处理多任务和提高性能的重要手段。

相关推荐
呉師傅32 分钟前
UPS滴滴告警!如何测量UPS电池内阻【UPS学习】
运维·服务器·网络·学习·电脑
lizhihai_9937 分钟前
股市学习心得-与英伟达核心 PCB 相关的八家关联企业
大数据·人工智能·学习
阳光宅男@李光熠2 小时前
【电子通识】贴片电阻上的丝印332、5R6、1502、01C怎么读出阻值?
笔记·学习
iCxhust2 小时前
AD0808调试笔记
笔记·单片机·嵌入式硬件·操作系统·微机原理·8088单板机
sakiko_4 小时前
Swift学习笔记31-网络请求
网络·笔记·学习·swift
星夜夏空994 小时前
STM32单片机学习(20) —— 利用中断实现串口通信(填前面的坑)
stm32·单片机·学习
神谕的祝福4 小时前
comfyui从0到1开始学习-第一讲安装ComfyUI
学习
名字不相符4 小时前
ctfshow之MISC入门(个人记录与学习)
学习·ctf·misc
创业之路&下一个五年4 小时前
自聚合树形业务:泛型基类+继承 设计思想完整总结(含核心原理与落地案例)
学习·总结
wuxinyan1235 小时前
工业级大模型学习之路023:LangChain零基础入门教程(第六篇):重排序与高级检索策略
人工智能·python·学习·langchain