ERROR IN THIS CODE!! import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Random; class Task { String name; int priority; int burstTime; int arrivalTime; Task(String name, int priority, int burstTime) { this.name = name; this.priority = priority; this.burstTime = burstTime; } } public class SchedulingAlgorithms { private static List taskSet; public static void main(String[] args) { initializeTaskSet(); // FCFS Thread fcfsThread = new Thread(() -> { System.out.println("FCFS Schedule:"); executeFCFS(); }); // SJF Thread sjfThread = new Thread(() -> { System.out.println("\nSJF Schedule:"); executeSJF(); }); // Priority Scheduling Thread priorityThread = new Thread(() -> { System.out.println("\nPriority Schedule:"); executePriority(); }); // Round-Robin Thread rrThread = new Thread(() -> { System.out.println("\nRound-Robin Schedule:"); executeRoundRobin(); }); fcfsThread.start(); sjfThread.start(); priorityThread.start(); rrThread.start(); try { fcfsThread.join(); sjfThread.join(); priorityThread.join(); rrThread.join(); } catch (InterruptedException e) { e.printStackTrace(); } } private static void initializeTaskSet() { taskSet = new ArrayList<>(); taskSet.add(new Task("T1", 2, 20)); taskSet.add(new Task("T2", 4, 25)); taskSet.add(new Task("T3", 3, 25)); taskSet.add(new Task("T4", 3, 15)); taskSet.add(new Task("T5", 1, 10)); // Assign random arrival times in the range [0, 100] Random random = new Random(); for (Task task : taskSet) { task.arrivalTime = random.nextInt(101); } // Sort tasks based on arrival time Collections.sort(taskSet, (t1, t2) -> Integer.compare(t1.arrivalTime, t2.arrivalTime)); } private static void executeFCFS() { int currentTime = 0; int totalWaitTime = 0; int totalTurnaroundTime = 0; for (Task task : taskSet) { int waitTime = currentTime - task.arrivalTime; totalWaitTime += waitTime; int turnaroundTime = waitTime + task.burstTime; totalTurnaroundTime += turnaroundTime; System.out.println(task.name + ": " + currentTime + " - " + (currentTime + task.burstTime)); currentTime += task.burstTime; } printAverages(totalWaitTime, totalTurnaroundTime); } private static void executeSJF() { // Sort tasks based on burst time Collections.sort(taskSet, (t1, t2) -> Integer.compare(t1.burstTime, t2.burstTime)); executeFCFS(); // SJF is essentially FCFS after sorting by burst time } private static void executePriority() { int currentTime = 0; int totalWaitTime = 0; int totalTurnaroundTime = 0; for (Task task : taskSet) { int waitTime = currentTime - task.arrivalTime; totalWaitTime += waitTime; int turnaroundTime = waitTime + task.burstTime; totalTurnaroundTime += turnaroundTime; System.out.println(task.name + ": " + currentTime + " - " + (currentTime + task.burstTime)); currentTime += task.burstTime; } printAverages(totalWaitTime, totalTurnaroundTime); } private static void executeRoundRobin() { int currentTime = 0; int totalWaitTime = 0; int totalTurnaroundTime = 0; int timeQuantum = 10; List remainingTasks = new ArrayList<>(taskSet); while (!remainingTasks.isEmpty()) { for (Task task : new ArrayList<>(remainingTasks)) { int remainingBurstTime = Math.min(task.burstTime, timeQuantum); int waitTime = currentTime - task.arrivalTime; totalWaitTime += waitTime; int turnaroundTime = waitTime + remainingBurstTime; totalTurnaroundTime += turnaroundTime; System.out.println(task.name + ": " + currentTime + " - " + (currentTime + remainingBurstTime)); currentTime += remainingBurstTime; task.burstTime -= remainingBurstTime; if (task.burstTime == 0) { remainingTasks.remove(task); } } } printAverages(totalWaitTime, totalTurnaroundTime); } private static void printAverages(int totalWaitTime, int totalTurnaroundTime) { double averageWaitTime = (double) totalWaitTime / taskSet.size(); double averageTurnaroundTime = (double) totalTurnaroundTime / taskSet.size(); System.out.println("\nAverage Waiting Time: " + averageWaitTime); System.out.println("Average Turnaround Time: " + averageTurnaroundTime); } }
ERROR IN THIS CODE!!
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;
class Task {
String name;
int priority;
int burstTime;
int arrivalTime;
Task(String name, int priority, int burstTime) {
this.name = name;
this.priority = priority;
this.burstTime = burstTime;
}
}
public class SchedulingAlgorithms {
private static List<Task> taskSet;
public static void main(String[] args) {
initializeTaskSet();
// FCFS
Thread fcfsThread = new Thread(() -> {
System.out.println("FCFS Schedule:");
executeFCFS();
});
// SJF
Thread sjfThread = new Thread(() -> {
System.out.println("\nSJF Schedule:");
executeSJF();
});
// Priority Scheduling
Thread priorityThread = new Thread(() -> {
System.out.println("\nPriority Schedule:");
executePriority();
});
// Round-Robin
Thread rrThread = new Thread(() -> {
System.out.println("\nRound-Robin Schedule:");
executeRoundRobin();
});
fcfsThread.start();
sjfThread.start();
priorityThread.start();
rrThread.start();
try {
fcfsThread.join();
sjfThread.join();
priorityThread.join();
rrThread.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
private static void initializeTaskSet() {
taskSet = new ArrayList<>();
taskSet.add(new Task("T1", 2, 20));
taskSet.add(new Task("T2", 4, 25));
taskSet.add(new Task("T3", 3, 25));
taskSet.add(new Task("T4", 3, 15));
taskSet.add(new Task("T5", 1, 10));
// Assign random arrival times in the range [0, 100]
Random random = new Random();
for (Task task : taskSet) {
task.arrivalTime = random.nextInt(101);
}
// Sort tasks based on arrival time
Collections.sort(taskSet, (t1, t2) -> Integer.compare(t1.arrivalTime, t2.arrivalTime));
}
private static void executeFCFS() {
int currentTime = 0;
int totalWaitTime = 0;
int totalTurnaroundTime = 0;
for (Task task : taskSet) {
int waitTime = currentTime - task.arrivalTime;
totalWaitTime += waitTime;
int turnaroundTime = waitTime + task.burstTime;
totalTurnaroundTime += turnaroundTime;
System.out.println(task.name + ": " + currentTime + " - " + (currentTime + task.burstTime));
currentTime += task.burstTime;
}
printAverages(totalWaitTime, totalTurnaroundTime);
}
private static void executeSJF() {
// Sort tasks based on burst time
Collections.sort(taskSet, (t1, t2) -> Integer.compare(t1.burstTime, t2.burstTime));
executeFCFS(); // SJF is essentially FCFS after sorting by burst time
}
private static void executePriority() {
int currentTime = 0;
int totalWaitTime = 0;
int totalTurnaroundTime = 0;
for (Task task : taskSet) {
int waitTime = currentTime - task.arrivalTime;
totalWaitTime += waitTime;
int turnaroundTime = waitTime + task.burstTime;
totalTurnaroundTime += turnaroundTime;
System.out.println(task.name + ": " + currentTime + " - " + (currentTime + task.burstTime));
currentTime += task.burstTime;
}
printAverages(totalWaitTime, totalTurnaroundTime);
}
private static void executeRoundRobin() {
int currentTime = 0;
int totalWaitTime = 0;
int totalTurnaroundTime = 0;
int timeQuantum = 10;
List<Task> remainingTasks = new ArrayList<>(taskSet);
while (!remainingTasks.isEmpty()) {
for (Task task : new ArrayList<>(remainingTasks)) {
int remainingBurstTime = Math.min(task.burstTime, timeQuantum);
int waitTime = currentTime - task.arrivalTime;
totalWaitTime += waitTime;
int turnaroundTime = waitTime + remainingBurstTime;
totalTurnaroundTime += turnaroundTime;
System.out.println(task.name + ": " + currentTime + " - " + (currentTime + remainingBurstTime));
currentTime += remainingBurstTime;
task.burstTime -= remainingBurstTime;
if (task.burstTime == 0) {
remainingTasks.remove(task);
}
}
}
printAverages(totalWaitTime, totalTurnaroundTime);
}
private static void printAverages(int totalWaitTime, int totalTurnaroundTime) {
double averageWaitTime = (double) totalWaitTime / taskSet.size();
double averageTurnaroundTime = (double) totalTurnaroundTime / taskSet.size();
System.out.println("\nAverage Waiting Time: " + averageWaitTime);
System.out.println("Average Turnaround Time: " + averageTurnaroundTime);
}
}
data:image/s3,"s3://crabby-images/06a7b/06a7bb4a9c1bd5ae97c96a42d325b4a1ca2d3f56" alt="at SchedulingAlgorithms.lambda$main$0(SchedulingAlgorithms.java:28)
at
Exception in thread "Thread-2" java.util.ConcurrentModificationException
at java.base/java.ut...
java.base/java.lang.Thread.run(Thread.java:829)"
data:image/s3,"s3://crabby-images/08195/08195f8f9d14ca7f7379d36affd5ded49e073b25" alt="Exception in thread "Thread-0" java.util.ConcurrentModificationException
at java.base/java.util.ArrayList$Itr.checkForComodification (ArrayList.java:1043)
at java.base/java.util.ArrayList$Itr.next(ArrayList.java:997)
at SchedulingAlgorithms.executeFCFS (SchedulingAlgorithms.java:88)"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Step by step
Solved in 4 steps with 1 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"