Tag Archives: Context Switching

⚙️ Process Management


🌐 Introduction to Process Management

Image
Image
Image

Process Management is a fundamental function of an operating system (OS) that handles the creation, scheduling, execution, and termination of processes. It ensures that multiple programs can run efficiently and concurrently on a computer system.

In simple terms:

Process management = controlling and coordinating program execution

A process is a program in execution, including its code, data, and state.


🧠 Importance of Process Management

  • Enables multitasking
  • Optimizes CPU utilization
  • Ensures fair resource allocation
  • Maintains system stability
  • Improves performance

🧩 Basic Concepts


📄 Program vs Process

FeatureProgramProcess
DefinitionStatic codeExecuting program
StatePassiveActive
Example.exe fileRunning application

🔁 Process States

Image
Image
Image

A process moves through different states:

  1. New – Being created
  2. Ready – Waiting for CPU
  3. Running – Executing
  4. Waiting (Blocked) – Waiting for I/O
  5. Terminated – Finished execution

🧠 Process Control Block (PCB)

Image
Image

PCB stores process information:

  • Process ID (PID)
  • Process state
  • CPU registers
  • Memory allocation
  • Scheduling information

⚙️ Process Scheduling


🧠 What is Scheduling?

Image
Image
Image
Image

Scheduling determines which process gets CPU time.


🔁 Types of Schedulers

  1. Long-term scheduler – selects processes
  2. Short-term scheduler – allocates CPU
  3. Medium-term scheduler – swaps processes

⚡ Scheduling Algorithms


🔹 1. First Come First Serve (FCFS)

Image
  • Processes executed in arrival order

🔹 2. Shortest Job First (SJF)

Image
Image
  • Shortest execution time first

🔹 3. Round Robin (RR)

Image
Image
  • Time-sharing system
  • Each process gets fixed time slice

🔹 4. Priority Scheduling

Image
Image
Image
  • Processes executed based on priority

⚖️ Scheduling Criteria

  • CPU utilization
  • Throughput
  • Turnaround time
  • Waiting time
  • Response time

🔄 Process Synchronization


🧠 Concept

Image
Image
Image
Image

Ensures safe access to shared resources.


⚠️ Critical Section Problem

  • Section where shared data is accessed

🔒 Solutions:

  • Mutex locks
  • Semaphores
  • Monitors

⚠️ Deadlocks


🧠 Definition

Image
Image
Image
Image

Deadlock occurs when processes wait indefinitely.


🔑 Conditions:

  1. Mutual exclusion
  2. Hold and wait
  3. No preemption
  4. Circular wait

🔄 Handling Deadlocks:

  • Prevention
  • Avoidance
  • Detection and recovery

🔁 Inter-Process Communication (IPC)


📡 Methods

Image
Image
Image
  • Shared memory
  • Message passing
  • Pipes
  • Sockets

🧠 Threads and Multithreading


🔹 Threads

Image
Image
  • Lightweight processes
  • Share memory

⚡ Benefits:

  • Faster execution
  • Better resource utilization

🔄 Context Switching


🧠 Concept

Image
Image
Image
Image
  • CPU switches between processes
  • Saves and loads state

🧩 Process vs Thread

FeatureProcessThread
MemorySeparateShared
OverheadHighLow
SpeedSlowerFaster

⚙️ Multiprocessing


🧠 Concept

Image
Image
Image
Image
  • Multiple CPUs/cores
  • Parallel execution

🧠 Real-Time Process Management


⚡ Types:

  • Hard real-time
  • Soft real-time

Used in:

  • Robotics
  • Embedded systems

🔐 Process Security


🛡️ Features:

  • Access control
  • Isolation
  • Sandboxing

⚡ Performance Optimization

  • Efficient scheduling
  • Load balancing
  • Minimizing context switches

⚠️ Challenges

  • Deadlocks
  • Starvation
  • Race conditions

🚀 Modern Trends

Image
Image
Image
Image
  • Containerization
  • Virtualization
  • Cloud computing
  • Microservices

🧾 Conclusion

Process management is a core function of operating systems that ensures efficient execution of programs. It enables:

  • Multitasking
  • Resource sharing
  • System stability

Understanding process management is essential for:

  • OS design
  • Software development
  • Performance optimization

🏷️ Tags