《Operating Systems:Three easy pieces》:2.3 并发性

探讨了并发编程中的关键问题,包括多线程程序设计、共享资源访问冲突及解决方案。通过实例分析,深入理解指令执行顺序对程序结果的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2.3 并发性

当在相同的内存空间中有许多并发执行的线程时,我们如何构建一个正确工作的程序?操作系统需要哪些基本类型?硬件应该提供哪些机构?我们如何使用它们来解决并发性问题?

本书另一个很重要的主题是并发性。我们使用这样一个概念术语去描述同一个程序要同时处理多个任务时会发生的并要求解决的一些问题。并发性问题首先出现在操作系统本身中;正如上述你看到的一些虚拟化的例子,操作系统同时处理许多事情,先运行一个进程,然后另一个,等等。人们后来会发现,这么做会引起许多影响深刻并有趣的事情。

一个多线程程序示例:threads.c

不幸的是,并发性问题不再仅仅局限于操作系统本身。现代多线程程序也出现了同样的问题。让我们看看示例程序threads.c。

即使此刻你不能完全理解这个例子(我们将在后续的章节并发性中,学习这个例子的有关知识),基本思想很简单。主程序使用pthreads_create()创建了两个线程。你可以把线程看做与其他函数共享内存空间的一个函数,在他们中可以有一个以上的同时在活动中。在这个例子中,每个线程都在一个称为worker()的例程中开始运行,在这个例程中,它只是在一个循环中增加计数器的循环次数。

下面是运行这个程序时发生的事情,变量循环的输入值设置为1000。loops的值将决定在一个循环中,这两个worker每个将增加共享计数器多少次。当我们将值设置为1000时,你预期计数器最后的值将会是多少?

你可能猜到了,当这两个线程结束的时候,计数器最后的值是2000次,每个计数器增加1000次。真的,我们希望当我们输入值为N时,我们预期输出结果为2N,但是事实证明,生活常常不会如此简单,我们给Loops一个更大的值,运行这个同样的程序,看他会输出我们的预期结果吗?

在这个过程中,当我们输入值为100,000时,我们得到的不是200,000的最终值,而是143,012。然后,当我们再次运行程序时,我们不仅再次得到错误的值,而且与上次得到的值不同。事实上,如果您用循环的高值一遍又一遍地运行该程序,您可能会发现有时甚至会得到正确的答案!为什么会这样呢?

事实证明,这些奇怪和不寻常的结果的原因与指令如何执行有关,而指令是一次执行一个。不幸的是,上面程序的一个关键部分,也就是增加共享计数器的部分,需要三条指令:一是将计数器的值从存储器装入寄存器,一个是增加1,一个是重新存进存储器。因为这三条指令不是原子执行,所以奇怪的事情就这样发生了。我们将在本书的第二部分详细讨论并发性问题。

### 回答1: "Operating Systems: Three Easy Pieces"(操作系统:三步轻松学)是一本由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau编写的计算机科学教材。本书旨在介绍操作系统背后的核心原理和概念,以及其在计算机系统中的作用。 该书的内容涵盖了操作系统的多个方面,包括进程管理、内存管理、文件系统、输入输出、虚拟化、并发与并行等。它提供了广泛的范围,旨在帮助读者全面了解操作系统的基本概念和内部工作原理。 该书的第一部分介绍了操作系统的基本概念,例如进程、线程和调度算法。它解释了多任务处理的基本原理,并讨论了与并发性和并行性相关的问题。 第二部分讨论了内存管理和虚拟化技术,包括分页、分段、内存分配和页面置换等。它还讨论了操作系统如何处理死锁和内存泄漏等问题。 第三部分则专注于文件系统和存储技术。它解释了文件系统的层次结构和存储管理,以及如何实现文件和目录的访问控制和保护机制。 总的来说,《操作系统:三步轻松学》这本书以易于理解和深入浅出的方式,介绍了操作系统的关键概念和原理。它旨在帮助读者建立对操作系统的基本了解,以及如何设计和实现一个高效稳定的操作系统。无论是计算机科学专业的学生、软件开发人员还是系统管理员,都可以从这本书中获得宝贵的知识和见解,以提升对操作系统的理解和应用能力。 ### 回答2: 《操作系统:三个简单的组成部分》是一本关于操作系统的英文书籍。该书由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau合著。这本书旨在以简洁易懂的方式介绍操作系统的基本概念和原理。 书中主要涵盖操作系统的三个组成部分,即虚拟化、并发性和持久性。虚拟化是指操作系统利用物理资源来创建多个虚拟资源的能力,例如虚拟内存,使得多个程序可以在同一台机器上同时运行。并发性涉及操作系统如何管理和调度同时运行的多个任务。持久性是指操作系统如何管理和访问长期存储,例如硬盘或闪存。 书中通过详细的示例和清晰的解释,阐述了各种操作系统的基本概念和常见问题的解决方案。它还介绍了操作系统的设计原则和优化技术,以及一些常见的操作系统功能,如进程管理、内存管理和文件系统。 这本书是为初学者和其他对操作系统感兴趣的人编写的,而且不需要太多的预备知识。它的目标是帮助读者理解操作系统的基本原理和如何实现它们。 总之,《操作系统:三个简单的组成部分》是一本很好的操作系统入门书籍,它以易读易懂的方式介绍了操作系统的基本概念和原理。无论是对于学生、软件工程师还是对操作系统感兴趣的人来说,这本书都会提供有价值的知识和见解。 ### 回答3: 《操作系统:三部简单的作品》是一本关于操作系统的英文书籍。这本书由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau撰写,旨在介绍操作系统的基本原理和概念。 该书主要分为三个部分,每个部分都涵盖一个关键主题。第一部分介绍了操作系统的概述和基本概念,包括进程、线程、调度、同步和死锁等。它通过一系列易懂的例子和实验帮助读者理解这些概念,并展示它们在实际操作系统中的应用。 第二部分深入讨论了操作系统的内存管理和虚拟内存的原理。它解释了内存分配、地址转换和页面置换等重要的内存管理技术,以及虚拟内存的概念和工作原理。读者可以通过实践性的编程练习来巩固所学知识。 最后一部分探讨了文件系统和存储技术。它介绍了文件系统的组织和功能,包括文件的访问权限、目录结构和磁盘调度算法。此外,它还讨论了存储技术的发展,例如RAID和闪存。 《操作系统:三部简单的作品》以其简洁明了的风格和通俗易懂的示例而闻名。它适用于那些对操作系统感兴趣的初学者和教育者。读者无需具备深厚的计算机科学背景,即可轻松理解书中的内容。 总之,这本书是一本介绍操作系统基本原理和概念的优秀教材。通过阅读《操作系统:三部简单的作品》,读者可以建立起对操作系统的深入理解,从而在实践中更好地应用和开发操作系统
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值