CPU Scheduling Algorithms

 Certainly, let's explain each CPU scheduling algorithm in a more formal manner:


### First Come, First Served (FCFS)

- **Description**: FCFS is a non-preemptive CPU scheduling algorithm where processes are executed in the order they arrive in the ready queue.

- **Operation**: Upon arrival, processes are added to the end of the ready queue. The CPU is allocated to the first process in the queue, which continues execution until it completes its CPU burst or enters an I/O wait state. Subsequent processes are selected for execution based on their arrival order.

- **Characteristics**:

  - **Advantages**: Simple implementation, fair execution order.

  - **Disadvantages**: Potential for poor response time and inefficient CPU utilization, especially with long-running processes.


### Shortest Job First (SJF)

- **Description**: SJF is a CPU scheduling algorithm that selects the process with the shortest expected CPU burst time for execution.

- **Operation**: Processes are selected for execution based on their CPU burst time, with the shortest job given priority. This algorithm can be preemptive or non-preemptive.

- **Characteristics**:

  - **Advantages**: Optimal average waiting time, efficient CPU utilization for short processes.

  - **Disadvantages**: Potential for starvation of longer processes if shorter ones continually arrive.


### Round Robin (RR)

- **Description**: RR is a CPU scheduling algorithm that allocates a fixed time slice to each process in a cyclic manner.

- **Operation**: Processes are placed in a ready queue and are executed for a predefined time quantum. If a process does not complete within its time slice, it is preempted and placed at the end of the ready queue.

- **Characteristics**:

  - **Advantages**: Fair allocation of CPU time, prevents process starvation.

  - **Disadvantages**: Overhead from frequent context switches, potential for increased response time with longer time slices.


### Priority Scheduling

- **Description**: Priority scheduling is a CPU scheduling algorithm that assigns priority levels to processes and executes higher-priority processes first.

- **Operation**: Each process is assigned a priority value, and the CPU scheduler selects the process with the highest priority for execution. Preemption may occur if a higher-priority process becomes available.

- **Characteristics**:

  - **Advantages**: Allows for prioritization of important tasks, suitable for real-time systems.

  - **Disadvantages**: Potential for starvation of lower-priority processes, may lead to inefficiencies if priorities are not managed effectively.


### Multilevel Queue Scheduling

- **Description**: Multilevel queue scheduling partitions the ready queue into multiple queues, each with its own scheduling algorithm and priority level.

- **Operation**: Processes are assigned to different queues based on criteria such as priority or process type. Each queue operates independently, with processes serviced according to their priority level and the scheduling algorithm of their respective queue.

- **Characteristics**:

  - **Advantages**: Allows for management of diverse process types and priorities, efficient resource allocation.

  - **Disadvantages**: Complexity in managing multiple queues and scheduling algorithms, potential for increased overhead.



**Multilevel Feedback Queue (MLFQ) Scheduling:**

- MLFQ categorizes tasks into multiple queues based on priority.

- Tasks move between queues depending on their urgency and behavior.

- Initially, tasks start in high-priority queues for prompt execution.

- Each queue has a time limit for task execution, shorter for high-priority queues.

- Tasks are selected for execution from the highest-priority non-empty queue.

- MLFQ dynamically adjusts task priorities based on their behavior during execution.

- It's effective for balancing responsiveness and maximizing CPU utilization.


**Processor Affinity:**

- Processor affinity assigns specific tasks to specific processors or cores.

- This reduces cache thrashing by keeping tasks localized to certain processors.

- Tasks can be either hard-affined (stays on one processor) or soft-affined (preferred but can move).

- Affinity improves cache locality, especially in NUMA systems.

- It enhances overall system performance by minimizing cache misses and memory access latency.

- Affinity can be applied at the thread level in multithreaded applications.

- It requires careful management to balance performance gains with overall system throughput.


**Shortest Remaining Time (SRT) Scheduling:**

- SRT prioritizes tasks based on their remaining execution time.

- When a new task arrives, it compares its time to completion with currently running tasks.

- If the new task can finish sooner, it preempts the current task and starts executing.

- Preemption involves pausing the current task, saving its state, and switching to the new task.

- SRT dynamically adjusts task priorities based on their remaining execution times.

- It minimizes response time but can increase overhead due to frequent preemptions.

- SRT is commonly used in real-time systems to meet strict deadlines.


**Real-time Scheduling:**

- Real-time scheduling organizes tasks to meet deadlines.

- Feasibility and schedulability are crucial; tasks must complete on time.

- Different scheduling policies exist, like Earliest Deadline First (EDF) and Rate-Monotonic (RM).

- Feasibility refers to the proof that tasks will complete within their deadlines.

- Schedulability means there's a feasible schedule for the tasks.

- Utilization measures how much time the scheduler is active versus allocated tasks.

- Real-time scheduling is vital in areas like embedded systems, networking, and aerospace.

Comments

Popular posts from this blog

SE

2.16 - 2.20

Synchronization