wisemonkeys logo
FeedNotificationProfileManage Forms
FeedNotificationSearchSign in
wisemonkeys logo

Blogs

Concurrency and Deadlocks

profile
Akshat Gohil
Aug 12, 2024
0 Likes
0 Discussions
152 Reads

Concurrency:

Concurrency refers to the ability of the Operating Systems to execute multiple of processes or threads simultaneously for making efficient usage of CPU time/resources.

Processes are nothing but an instance of a program that is running with its own memory space.

 

OSes uses Context Switching mechanism to implement concurrency. It is the process of saving the current state of a currently executing process or thread and restoring other process or thread. This allows OS to switch between tasks giving an illusion of simultaneous execution.

Concurrency in OS leads to problems like Deadlock and Starvation.

 

Deadlock:

A deadlock is a situation when two are more processes are unable to proceed because each process is waiting for other to release a resource. This leads to a state where none of the processes can continue and they’re stuck indefinitely.

Deadlocks occur when several conditions are met simultaneously:

Mutual Exclusion: Resources are not shared and can be allocated to only one process at a time.

Hold and Wait: A process holding particular resources can request additional resources without releasing currently held.

No Preemption: Resources cannot be taken forcibly from resources and they must be freed simultaneously.

Circular Chain: A circular chain of process where processes wait for other to release resources held by them.

 

Deadlock Prevention:

Deadlock prevention ensures that at least one of the four conditions will not come true and will not lead to a deadlock from occurring.

Prevent Mutual Exclusion: Design systems where minimum number of resources are non-shareable, or convert non-shareable resources to shareable ones if possible reducing the probability of having deadlock.

Prevent Hold and Wait: Processes should request all the necessary resources before execution. If all resources not available it waits for them.

 

Prevent No Preemption: Allow pre-emption of resources where necessary to break deadlock conditions. If P2 needs a resource that P1 holds, P1 is forced to release its resource and wait until both resources are available. The system preempts P1, breaking the deadlock condition.

 

Prevent Circular Wait: Give each resource a unique priority. A process can only request resources in increasing order of their priority. This ensures there is always a linear dependency preventing circular wait.

 

Deadlock Avoidance:

Deadlock Avoidance dynamically decisions are made whether the granting the resource will potentially lead a deadlock.

A process is not granted a resource if it might lead to a deadlock.

Deadlock avoidance allows processes to request resources that prevents the system from entering a deadlock.

 

 

 

 

 

­­­­­­­

 


Comments ()


Sign in

Read Next

Types of Threads

Blog banner

IT GOVERNANCE

Blog banner

Smartphone Security: Vulnerabilities and Attacks

Blog banner

Direct memory access

Blog banner

What is Virtual Memory

Blog banner

Scheduling

Blog banner

MEMORY FORENSIC ACQUISITION AND ANALYSISOF MEMORY AND ITS TOOLS COMPARISON

Blog banner

RAID

Blog banner

The Sunny Side of Instagram

Blog banner

WHAT IS SNAPCHAT AND HOW DOES IT WORK?

Blog banner

Types of threads

Blog banner

Modern Operating System - Khush Bagaria

Blog banner

Why is it hard to design an Operating Systems ?

Blog banner

Navigation With Indian Constellation(NavIC) by ISRO in Geographic Information Systems

Blog banner

How to Plan a Week of Healthy Meals Without Stress

Blog banner

Understanding Regression Analysis

Blog banner

Mumbai Metro 3

Blog banner

Points to consider if you're planning to visit Florida in 2026

Blog banner

Save Girl Child

Blog banner

Philadelphia Experiment : Was it real?

Blog banner

THE DESIRE OF MANY

Blog banner

E-learning in today's world

Blog banner

How to kiss

Blog banner

What is Email? Uses of Emails

Blog banner

Virtual machine and virtualizing

Blog banner

Starvation

Blog banner

Evolution of OS

Blog banner

Constrained Management in IT

Blog banner

Im Photographer

Blog banner

Flipkart

Blog banner

SPEM

Blog banner

Europe Through My Lens

Blog banner

Is It Too Late to Straighten My Teeth as an Adult?

Blog banner

Interesting fact about kangaroo.

Blog banner

Getting into anime My anime suggestions

Blog banner

Social Media Marketing Trends 2022

Blog banner

Supervised and Unsupervised Learning

Blog banner

File management

Blog banner

How to Compare Schools Before an Admission Decision

Blog banner

Top Career Paths After a B.Com Degree in Mumbai: What’s Next for You?

Blog banner

Risk factors in service transistion

Blog banner

Health and fitness

Blog banner