Skip to content

Commit

Permalink
Merge pull request #20 from Ogu1208/feature/#18-SRT
Browse files Browse the repository at this point in the history
#18 - SRT 스케줄링 구현
  • Loading branch information
Ogu1208 authored Jun 10, 2023
2 parents bb2a3b5 + 782e14c commit d214fd3
Show file tree
Hide file tree
Showing 3 changed files with 133 additions and 1 deletion.
13 changes: 13 additions & 0 deletions src/Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ public static void main(String[] args) {
hrn();
System.out.println("-----------------RR-----------------");
rr();
System.out.println("-----------------SRT-----------------");
srt();
}


Expand Down Expand Up @@ -80,6 +82,17 @@ public static void rr()
display(rr);
}

public static void srt()
{
CPUSchedulingAlgorithm srt = new SRT();
srt.setTimeQuantum(10);
srt.addRow(new Row("P1", 0,30));
srt.addRow(new Row("P2", 3, 18));
srt.addRow(new Row("P3", 6, 9));
srt.process();
display(srt);
}

public static void display(CPUSchedulingAlgorithm object)
{
System.out.println("Process\tAT\tBT\tWT\tTAT\tRT");
Expand Down
2 changes: 1 addition & 1 deletion src/RoundRobin.java
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ public void process() {

// 만약 프로세스의 burstTime이 timeQuantum보다 크다면
if (row.getBurstTime() > timeQuantum) {
// burtTime을 bursttime - timeQuantum으로 갱신
// burtTime을 burstTime - timeQuantum으로 갱신
row.setBurstTime(row.getBurstTime() - timeQuantum);

// timequantum만큼 일한 프로세스 row를 큐의 뒤에 추가
Expand Down
119 changes: 119 additions & 0 deletions src/SRT.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
import java.util.*;

public class SRT extends CPUSchedulingAlgorithm {
@Override
public void process() {
// Sort list of objects using Collection.sort() with lambdas only
// 도착시간(ArrivalTime)을 기준으로 빠른순으로 정렬한다. (도착한 순서대로)
Collections.sort(this.getRows(), (Object o1, Object o2) -> {
if (((Row) o1).getArrivalTime() == ((Row) o2).getArrivalTime()) {
return 0;
} else if (((Row) o1).getArrivalTime() < ((Row) o2).getArrivalTime()) {
return -1;
} else {
return 1;
}
});

// rows = this.getRows를 깊은 복사
List<Row> rows = Utility.deepCopy(this.getRows());
int time = rows.get(0).getArrivalTime(); // 첫 번째 프로세스의 도착시간

// time Quantum 설정
int timeQuantum = this.getTimeQuantum();

while (!rows.isEmpty()) {
// available Row의 List를 만든다.
List<Row> availableRows = new ArrayList();

// for문을 돌며 time보다 row의 도착시간이 작거나 같으면 available Row에 추가한다.
for (Row row : rows) {
if (row.getArrivalTime() <= time) {
availableRows.add(row);
}
}

// burstTime이 작은(남아있는 작업 시간이 가장 적은 순)으로 정렬한다. (Shortest Remaining Time)
Collections.sort(availableRows, (Object o1, Object o2) -> {
if (((Row) o1).getBurstTime() == ((Row) o2).getBurstTime()) {
return 0;
} else if (((Row) o1).getBurstTime() < ((Row) o2).getBurstTime()) {
return -1;
} else {
return 1;
}
});

// 가능한 rows들 중 burstTime이 가장 적은 row(process)를 구한다.
Row row = availableRows.get(0);

// 한 텀의 burst time 계산
// (timeQuantum보다 burstTime이 작으면 burstTime만큼, 아니라면 timeQuantum만큼 실행)
int bt = (row.getBurstTime() < timeQuantum ? row.getBurstTime() : timeQuantum);

// timeline(List<Event>)에 burstTime이 가장 작은(남아있는 작업 시간이 가장 적은) row(process)의 Event를 추가
// startTime : time
// finishTime : time + row의 bt
this.getTimeline().add(new Event(row.getProcessName(), time, time + bt));
time += bt; // time 갱신 (timme+=bt)

// row의 burstTime = burstTime - bt 로 업데이트
row.setBurstTime(row.getBurstTime() - bt);

// 만약 해당 process의 burstTime이 끝났다면, 같은 이름의 프로세스를 찾아 rows행에서 remove시킨다.
if (row.getBurstTime() == 0) {
for (int i = 0; i < rows.size(); i++) {
if (rows.get(i).getProcessName().equals(row.getProcessName())) {
rows.remove(i);
break;
}
}
}
}

// for문으로 Event의 List를 뒤에서부터 거꾸로 찾으면서
for (int i = this.getTimeline().size() - 1; i > 0; i--) {
List<Event> timeline = this.getTimeline();

// timeline의 마지막 프로세스와 마지막-1의 프로세스가 같다면
if (timeline.get(i - 1).getProcessName().equals(timeline.get(i).getProcessName())) {
// 마지막-1의 프로세스의 finishTime을 마지막 프로세스의 finishTime으로 업데이트하고
timeline.get(i - 1).setFinishTime(timeline.get(i).getFinishTime());
// 마지막 프로세스를 삭제한다.
timeline.remove(i);
}
}

Map map = new HashMap();

// for문을 돌며 row와 evnet 비교
for (Row row : this.getRows()) {
map.clear();

// waitingTime = 시작 시작 - 도착 시간
for (Event event : this.getTimeline()) {
// row와 evnet의 프로세스 이름이 같으면
if (event.getProcessName().equals(row.getProcessName())) {
// map에 프로세스 이름의 key가 있다면 (이미 한번 이상 burstTime만큼 작업했다면)
if (map.containsKey(event.getProcessName())) {
// 기존 waitingTime에 (이전에 작업했을 때의 finishTime - 이번 작업의 startTime)을 더함.
int w = event.getStartTime() - (int) map.get(event.getProcessName());
row.setWaitingTime(row.getWaitingTime() + w);
}
// 아직 map에 프로세스 이름의 key가 없다면
else { // row의 waitingTime을 startTime - ArrivalTime으로 초기화
row.setWaitingTime(event.getStartTime() - row.getArrivalTime());
}

// map에 key : processName, value: finishTime을 삽입
map.put(event.getProcessName(), event.getFinishTime());
}
}

// turnAroundTime = 대기 시간 + 실행 시간(burst time)
row.setTurnaroundTime(row.getWaitingTime() + row.getBurstTime());
// responseTime = 첫 작업을 시작한 후 첫 번째 출력(반응)이 나오기 전까지 시간
row.setResponseTime(row.getWaitingTime() + 1);
}
}
}

0 comments on commit d214fd3

Please sign in to comment.