Unit 3: Synchronization
Because a number of different entities will need to access data, it is important to learn how to maintain a consistent view of data across the OS. This is why we need a good synchronization management system. We will begin this section with an overview of why synchronization is so important to an Operating System and the problems that could arise if synchronization is not handled properly. The discussion will continue with an overview of Race Conditions (or system flaws in which the output of a given process is problematically dependent on the sequence of other events), and finally, Semaphores as a way of preventing Race Conditions and other more advanced alternatives to Semaphores, such as Monitors and Messages.
Completing this unit should take you approximately 12 hours.
Upon successful completion of this unit, you will be able to:
- describe synchronization;
- explain a race condition;
- discuss interprocess communication;
- describe how semaphores can be used in an operating system;
- discuss three of the classic synchronization problems; and
- explain the alternatives to semaphores.
3.1: Synchronization: Relevance and Problems
Watch this lecture.
Read chapter 1 on pages 1–6.
3.2: Race Conditions
Read these slides.
3.3: Semaphores
Watch this lecture.
Read chapter 2 on pages 7–9 and chapter 4 on pages 61–120.
Read this page.
Watch this lecture.
Read this document.