java, الگوریتم زمان‌بندی, الگوریتم زمان‌بندی در جاوا, جاوا

الگوریتم زمان‌بندی SJF در جاوا (Short Job First)

الگوریتم زمان‌بندی SJF در جاوا

این جلسه ما را با ادامه آموزش الگوریتم‌های زمان‌بندی همراهی کنید. در این قسمت به آموزش الگوریتم زمان‌بندی SJF در جاوا می‌پردازیم. ابتدا این الگوریتم را معرفی و سپس به پیاده‌سازی آن خواهیم پرداخت. پیشنهاد می‌کنیم قبل از مطالعه این جلسه، آموزش‌های زیر را مطالعه کنید:

  1. الگوریتم Round Robin در جاوا
  2. الگوریتم FCFS در جاوا
  3. متد در جاوا
  4. Arraylist در جاوا
  5. شی گرایی در جاوا
  6. مرتب سازی حبابی در جاوا
  7. Constructor در جاوا
  8. حلقه for در جاوا
  9. حلقه while در جاوا
  10. If در جاوا

الگوریتم زمان‌بندی SJF

Shortest Job First یا به اختصار SJF یک الگوریتم زمان‌بندی در سیستم عامل است. در این الگوریتم، از بین فرایندهای منتظر در صف اجرا، فرایندی انتخاب می‌شود که به کوتاه‌ترین زمان برای اجرا شدن(burst Time) نیاز داشته باشد. این جا به چند ویژگی SJF اشاره می‌کنیم:

  • SJF پایین ترین میانگین زمان انتظار (average waiting Time) در بین الگوریتم‌های زمان‌بندی دارد.
  • SJF یک الگوریتم حریصانه است.
  • در این الگوریتم می‌تواند Starvation رخ دهد.

پیاده‌سازی الگوریتم زمان‌بندی SJF در جاوا

برای پیاده سازی الگوریتم زمان‌بندی SJF در جاوا مراحل زیر را انجام می‌دهیم:

  1. فرآیند‌های خود را تعریف می‌کنیم.
  2. بر اساس arrival Time ، فرآیند‌ها را وارد صف انتظار می‌کنیم.
  3. فرآیند‌های درون صف انتظار را بر اساس Burst Time مرتب می‌کنیم.
  4. به کوچکترین فرآیند CPU اختصاص می‌یابد.
  5. مراحل 2 تا 5 را تا زمان اتمام فرآیند‌ها ادامه می‌دهیم.

کد الگوریتم SJF در جاوا به صورت زیر است:

public class Process {
	int pid; // Process ID
	int bt; // Burst Time
	int art; // Arrival Time
	int completion_time;
	int waiting_time;
	int tat;//turn around time
	boolean is_finished = false;
	boolean addTowaiting = false;
	public Process(int pid, int bt, int art) {
		this.pid = pid;
		this.bt = bt;
		this.art = art;
	}
}
public class SJF {
	public static void main(String[] args) {
		ArrayList<Process> p = new ArrayList<>();
		p.add(new Process(1, 6, 1));
		p.add(new Process(2, 8, 1));
		p.add(new Process(3, 7, 2));
		p.add(new Process(4, 3, 3));
		SJF(p);
		CalWaitingTime(p);
		CalTurnAroundTime(p);
		display(p);
	}
	private static void CalTurnAroundTime(ArrayList<Process> p) {
		for (int i = 0; i < p.size(); i++) {
			p.get(i).tat = p.get(i).waiting_time + p.get(i).bt;
		}
	}
	public static void display(ArrayList<Process> p) {
		System.out.println
("Processes " + " Burst time " + " Waiting time " +
		" Turn around time" + " Completion Time " +" Arrival Time");
		for (int i = 0; i < p.size(); i++) {
			System.out.println
(" " + p.get(i).pid + "\t\t" +
		p.get(i).bt + "\t\t " + p.get(i).waiting_time + "\t\t "
					+ p.get(i).tat + "\t\t" + p.get(i).completion_time
					+ "\t\t" + p.get(i).art );
		}
	}
	public static void SJF(ArrayList<Process> AllProcess) {
		ArrayList<Process> waitingProcess = new ArrayList<>();
		int time = 0;
		int complete_process = 0;
		while (AllProcess.size() != complete_process) {
			CheckArrivalTime(AllProcess, waitingProcess, time);
			if (waitingProcess.size() <= 0) {
				time++;
				continue;
			}
			Sort(waitingProcess);
			Process shortestProcess = waitingProcess.get(0);
			time += shortestProcess.bt;
			shortestProcess.completion_time = time;
			shortestProcess.is_finished = true;
			waitingProcess.remove(0);
			complete_process++;
		}
	}
	public static void CalWaitingTime(ArrayList<Process> p) {
		for (int i = 0; i < p.size(); i++) {
			Process p1 = p.get(i);
			p1.waiting_time = p1.completion_time - p1.bt - p1.art;
			if (p1.waiting_time < 0) {
				p1.waiting_time = 0;
			}
		}
	}
	public static void Sort(ArrayList<Process> waitingProcess) {
		for (int i = 0; i < waitingProcess.size(); i++) {
			for (int j = 0; j < waitingProcess.size() - 1; j++) {
				Process p1 = waitingProcess.get(j);
				Process p2 = waitingProcess.get(j + 1);
				if (p2.bt < p1.bt) {
					Collections.swap(waitingProcess, j, j + 1);
				}
			}
		}
	}
	public static void CheckArrivalTime
(ArrayList<Process> Process,
			ArrayList<Process> waitingProcess, int time) {
		for (int i = 0; i < Process.size(); i++) {
			Process p = Process.get(i);
			if (p.art <= time && !p.addTowaiting) {
				p.addTowaiting = true;
				waitingProcess.add(p);
			}
		}
	}
}

ما برای پیاده‌سازی الگوریتم SJF از دو کلاس زیر استفاده کردیم:

  • Process: این کلاس برای تعریف یک فرآیند استفاده می‌شود و مواردی همچون Burst Time، arrival Time و waiting time و …. در آن تعریف شده است.
  • SJF: در این کلاس الگوریتم SJF پیاده سازی شده است.

متدهای کد فوق شامل موارد زیر است:

  • CheckArrivalTime: این متد زمان ورود فرآیندها را به صف انتظار بررسی می‌کند.
  • Sort: این متد صف انتظار ما را با روش مرتب سازی حبابی، مرتب می‌کند.
  • CalWaitingTime: محاسبه waiting time فرآیندها در این متد انجام می‌شود.
  • SJF: با کمک متدهای موارد بالا، الگوریتم SJF در این متد به اجرا در می‌آید.
  • Display: جهت نمایش فرآیند ها در خروجی از display استفاده می‌شود.

متغیرهای کد فوق:

  •  AllProcess یا p یا process: تمامی فرآیندها در Arraylist به نام AllProcess (p یا process) ذخیره می‌شوند.
  • waitingProcess: منظور صف انتظار ما است.
  • Bt: منظور burst time فرآیند است.
  • Art: منظور arrival Time است.
  • Tat: منظور turn around time است.

خروجی کد فوق به صورت زیر است:

نوشته های مشابه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *