Deadlock, Starvation and Livelock | Operating System - Computer Science Engineering (CSE) PDF Download

Deadlock


Deadlock, Starvation and Livelock | Operating System - Computer Science Engineering (CSE)

A deadlock occurs when each member of a group of actions is waiting for another member to release a lock. In contrast, a livelock is similar to a deadlock, but in a livelock, the states of the processes constantly change relative to each other, with none making any progress. Thus, livelock is a special case of resource starvation, as it involves processes that are not progressing.

Starvation

  • Starvation is a problem closely related to both livelock and deadlock.
  • In a dynamic system, requests for resources are continuous, necessitating a policy to decide who gets the resource and when.
  • Even with a reasonable policy, some processes may never get serviced, despite not being deadlocked.
  • Starvation occurs when certain threads, often described as "greedy," monopolize shared resources for extended periods.
  • This makes resources unavailable to other threads.
  • For example, consider an object with a synchronized method that takes a significant amount of time to complete.
  • If one thread calls this method frequently, other threads needing synchronized access may frequently find themselves blocked.

Livelock

Livelock occurs when two or more processes endlessly repeat the same interaction, continuously responding to changes in each other without making any progress. Unlike deadlock, where all processes are in a waiting state, processes in livelock are actively running concurrently but unable to perform any useful work.

Deadlock, Starvation and Livelock | Operating System - Computer Science Engineering (CSE)

Each of the two processes requires two resources and uses the polling primitive enter_reg to attempt to acquire the necessary locks. If the attempt fails, the process simply tries again. For instance, if Process A acquires Resource 1 first and Process B acquires Resource 2, neither process will make further progress, regardless of which one runs next. Instead of blocking, both processes repeatedly consume CPU time without making progress. This scenario is not a deadlock, as no process is blocked, but it is functionally equivalent to a deadlock: livelock.

What leads to Livelock? 

  • Livelock can arise in unexpected ways.
  • In some systems, the maximum number of allowed processes is limited by the number of entries in the process table.
  • This makes these table slots finite resources.
  • If a fork operation fails due to a full table, a reasonable approach is to wait for a random time before trying again.
  • For instance, consider a UNIX system with 100 process slots.
  • If ten programs are running and each needs to create 12 subprocesses, the table will be exhausted after each process creates 9 subprocesses.
  • At this point, the 10 original processes and the 90 new ones will have filled the table.
  • The original processes will then enter an endless loop of forking and failing.
  • This situation is essentially a deadlock.
  • Although the probability of this occurring is low, it is still possible.

Difference between Deadlock, Starvation, and Livelock

A livelock is similar to a deadlock, but in a livelock, the states of the involved processes constantly change relative to each other, with none making any progress. Livelock is a specific form of resource starvation in which a particular process is unable to make progress.

The document Deadlock, Starvation and Livelock | Operating System - Computer Science Engineering (CSE) is a part of the Computer Science Engineering (CSE) Course Operating System.
All you need of Computer Science Engineering (CSE) at this link: Computer Science Engineering (CSE)
10 videos|99 docs|33 tests

Top Courses for Computer Science Engineering (CSE)

FAQs on Deadlock, Starvation and Livelock - Operating System - Computer Science Engineering (CSE)

1. What is the difference between deadlock and starvation?
Ans.Deadlock occurs when two or more processes are unable to proceed because each is waiting for the other to release resources, resulting in a standstill. Starvation, on the other hand, happens when a process is perpetually denied the resources it needs to proceed, usually because other processes are continuously prioritized over it, leading to indefinite postponement.
2. What are the conditions necessary for a deadlock to occur?
Ans.For a deadlock to occur, four conditions must hold simultaneously: mutual exclusion (resources cannot be shared), hold and wait (process holding resources can request more), no preemption (resources cannot be forcibly taken), and circular wait (a circular chain of processes exists where each process is waiting for a resource held by the next).
3. How does livelock differ from deadlock?
Ans.Livelock is a situation where processes continuously change states in response to each other without making any progress, while deadlock is characterized by processes that are stuck waiting for each other. In livelock, processes are active but unable to complete their tasks, whereas in deadlock, they are inactive.
4. What strategies can be employed to prevent deadlock?
Ans.Strategies to prevent deadlock include resource allocation strategies like avoiding circular wait by imposing a strict ordering of resource requests, using the Banker's algorithm to ensure safe states, and implementing a timeout mechanism where processes are aborted if they wait too long for resources.
5. Can starvation lead to livelock?
Ans.Yes, starvation can lead to livelock if a process that is continuously denied resources ends up changing its state in an attempt to acquire them, but due to the system's scheduling policies, it ends up in a cycle of responding to other processes without making actual progress.
10 videos|99 docs|33 tests
Download as PDF
Explore Courses for Computer Science Engineering (CSE) exam

Top Courses for Computer Science Engineering (CSE)

Signup for Free!
Signup to see your scores go up within 7 days! Learn & Practice with 1000+ FREE Notes, Videos & Tests.
10M+ students study on EduRev
Related Searches

Previous Year Questions with Solutions

,

past year papers

,

Semester Notes

,

mock tests for examination

,

Extra Questions

,

Starvation and Livelock | Operating System - Computer Science Engineering (CSE)

,

ppt

,

study material

,

Summary

,

Exam

,

practice quizzes

,

Free

,

Starvation and Livelock | Operating System - Computer Science Engineering (CSE)

,

Deadlock

,

Objective type Questions

,

Deadlock

,

MCQs

,

Starvation and Livelock | Operating System - Computer Science Engineering (CSE)

,

Important questions

,

Viva Questions

,

video lectures

,

shortcuts and tricks

,

pdf

,

Sample Paper

,

Deadlock

;