wisemonkeys logo
FeedNotificationProfileManage Forms
FeedNotificationSearchSign in
wisemonkeys logo

Blogs

Deadlock

profile
Jeet Ved
Aug 15, 2024
0 Likes
0 Discussions
67 Reads

Concurrency in operating systems involves multiple processes or threads executing simultaneously, which can lead to complex interactions. Two common problems that arise in this context are deadlock and starvation. Here’s an overview of both:


1. *Deadlock*


A deadlock occurs when a set of processes or threads become stuck in a situation where each one is waiting for a resource that the others in the set are holding. Since none of them can proceed, they remain in this waiting state indefinitely. Four conditions are necessary for a deadlock to occur:


- *Mutual Exclusion:* At least one resource must be held in a non-sharable mode; only one process can use the resource at any given time.


- *Hold and Wait:* A process holding at least one resource is waiting to acquire additional resources that are currently being held by other processes.


- *No Preemption:* Resources cannot be forcibly taken away from a process; they must be released voluntarily.


- *Circular Wait:* A closed chain of processes exists, where each process holds a resource that the next process in the chain is waiting for.


*Example:* Consider two processes, P1 and P2. P1 holds Resource A and is waiting for Resource B, while P2 holds Resource B and is waiting for Resource A. Neither process can proceed, leading to a deadlock.


 *Deadlock Prevention and Avoidance*


- *Deadlock Prevention:* Modify one of the necessary conditions to ensure that a deadlock cannot occur (e.g., imposing a strict order on resource allocation to prevent circular wait).


- *Deadlock Avoidance:* Use algorithms (e.g., Banker's algorithm) to allocate resources in a way that ensures the system remains in a safe state.


 2. *Starvation*


Starvation, also known as indefinite blocking, occurs when a process is perpetually denied necessary resources because other processes keep gaining access to them first. Unlike deadlock, where processes stop making progress due to being stuck in a cycle, starvation involves one or more processes making no progress because they are continually bypassed.


*Example:* Consider a scheduling system where high-priority processes keep getting resources, and a low-priority process is continually skipped over, leading to starvation.


 *Solutions to Starvation*


- *Aging:* Gradually increase the priority of a waiting process over time to ensure it eventually gets the resources it needs.


- *Fair Scheduling Algorithms:* Use algorithms like round-robin or fair share that ensure all processes eventually receive attention.






Name:Jeet Ved


SAP ID:53003230116


DIV:B


Comments ()


Sign in

Read Next

VIRUS

Blog banner

Understanding E-mail Servers

Blog banner

An Approach To Spyware Detection And Removal

Blog banner

Proof-of-Stake (PoS)

Blog banner

Uniprocessor scheduling

Blog banner

The Future of Web Development in 2026: Trends Every Business Must Know

Blog banner

10 Interesting Facts about Attack on Titan

Blog banner

Cache Memory

Blog banner

Zomato's Secret Digital Marketing Techniques!

Blog banner

CSI and Organizational Change

Blog banner

Importance of business process documentation

Blog banner

File and File System Structure

Blog banner

Shoulders

Blog banner

Yoga in INDIA and ABROAD

Blog banner

indian premier league

Blog banner

Session Vulnerabilities

Blog banner

Introduction to Virtual Memory - 080

Blog banner

Data Lakes: A Key to Modern Data Management

Blog banner

memory cache

Blog banner

Guidelines for a low sodium diet.

Blog banner

Data-Driven Prediction of Virtual Item Prices in Online Games

Blog banner

KEAP MANAGEMENT SYSTEM

Blog banner

A-B-C of Networking: Part-1 (Basics)

Blog banner

Deadlock and starvation in operating system

Blog banner

Palm Vein Biometric Technology; Contactless vein authentication

Blog banner

Types of threads

Blog banner

Short note on Microsoft office

Blog banner

Computer Forensics and its Impact in Business Environment

Blog banner

Deadlocks

Blog banner

Landslide Hazard

Blog banner

Segmentation and paging concept

Blog banner

Have You Explored India Yet?

Blog banner

Introduction to Solidity Programming for Blockchain Development

Blog banner

GraphQL

Blog banner

The Impact of Cyber Forensics on Corporate Governance and Compliance

Blog banner

COMMUNICATION

Blog banner

URL vs Domain

Blog banner

Virtual Machine

Blog banner

Why You Should Not Use Free VPNs

Blog banner

The Joy of Giving: How Festivals Teach Children Empathy and Gratitude

Blog banner

Number Guessing game --lisp

Blog banner

ProofHub

Blog banner