Selasa, 17 Mei 2011

JAWABAN SO BAB 5


1.  Yg d maksd dgn race c0nditi0n.
Jawab: Race Condition adalah situasi di mana beberapa proses mengakses dan memanipulasi data bersama pada saat besamaan. Nilai akhir dari data bersama tersebut tergantung pada proses yang terakhir selesai. Unutk mencegah race condition, proses-proses yang berjalan besamaan haus di disinkronisasi.
2.  Yg dimaksud Critical secti0n, untk mnyelesaikn masalah critical secti0n ada 3 hal yg hrus dipenuhi, sbut dan jelaskn
Jawab:
Critical secti0n adalah Suatu system terdiri dari n proses dimana semuanya berkompetisi menggunakan
data yang digunakan bersama-sama, Masing-masing proses mempunyai sebuah kode
segmen.
3 hal yg harus d penuhi adalah
1. Mutual Exclusion. Apabila proses Pi menjalankan critical section-nya, maka tidak
ada proses lain yang dapat menjalankan critical section.
2. Progress. Apabila tidak ada proses yang menjalankan critical section-nya dan
terdapat beberapa proses yang akan memasuki critical section-nya, maka hanya
proses-proses itu yang tidak diproses di dalam daerah pengingat (remainder) dapat
ikut berpartisipasi di dalam keputusan proses mana yang akan memasuki critical
section selanjutnya, dan pemilihan ini tidak dapat ditunda tiba-tiba.
3. Bounded Waiting. Terdapat batasan jumlah waktu yang diijinkan oleh proses lain
untuk memasuki critical section setelah sebuah proses membuat permintaan untuk
memasuki critical section-nya dan sebelum permintaan dikabulkan.
3.  Bagaimana algoritma bakery untuk sinkronisasi banyakk pr0ses (n proses)
Jawab:
Pada algoritma bakery terdapat notasi <untuk urutan nomor (ticket #, process id #)
sebagai berikut :
(a,b) < (c,d) if a < c or if a = c and b < d
max (a0,…, an-1) is a number, k, such that k ai for i - 0,
…, n – 1
Variabel umum yang digunakan adalah :
boolean choosing[n];
int number[n];
Struktur data diatas diinisialisasi false dan 0. Struktur dari proses Pi adalah :
do {
choosing[i] = true;
number[i] = max(number[0], number[1], …, number [n – 1])+1;
choosing[i] = false;
for (j = 0; j < n; j++) {
while (choosing[j]) ;
while ((number[j] != 0) && (number[j],j < number[i],i)) ;
}
critical section
number[i] = 0;
remainder section
} while (1);
4.  Apa yg dimaksud semaph0re dan sebutkan operasi pada semaphore.
Jawab:
Semaphore adalah sebuah struktur data komputer yang digunakan untuk sinkronisasi proses, yaitu untuk memecahkan masalah di mana lebih dari satu proses atau thread dijalankan secara bersamaan dan harus diatur urutan kerjanya.

Oprasi pd semaphore adalah
 Operasi Down (P)
  • operasi ini menurunkan nilai semaphore
  • jika nilai semaphore menjadi non positif maka proses yang mengeksekusinya diblocked
Operasi Up (V)
  • Operasi ini menaikkan nilai semaphore
  • jika satu proses atau lebih telah di blocked pada suatu semaphore tak dapat menyelesaikan operasi Down, maka salah satu dipilih oleh sistem dan dibolehkan menyelesaikan operasi Down-nya
  • urutan proses yang dipilih tidak ditentukan oleh Dijkstra dapat dipilih secara acak, FIFO dll sesuai kepentingan
  • operasi UP menaikkan nilai semaphore, memindahkan dari antrian dan menempatkan proses ke antrian.

5.  Bagaimana struktur semaph0re yg digunakan untuk menylesaikan
a. B0unded buffer pr0blem.
B. Reader and writer pr0blem
c. Dining phil0s0pher pr0blem
Jawab:
a. B0unded buffer pr0blem.
Untuk penyelesaian permasalahan bounded buffer menggunakan semaphore
menggunakan variabel umum berikut :
semaphore full, empty, mutex;
Inisialisasi untuk variable diatas, full = 0, empty = n, mutex = 1. Struktur
program untuk produsen adalah
do {
menghasilkan item pada nextp
wait(empty);
wait(mutex);
menambah nextp ke buffer
signal(mutex);
signal(full);
} while (1);
Sedangkan struktur program untuk konsumen adalah
do {
wait(full)
wait(mutex);
mengambil item dari buffer ke nextc
signal(mutex);
signal(empty);
menggunakan item pada nextc
} while (1);

B. Reader and writer pr0blem
Variabel umum yang digunakan
adalah
semaphore mutex, wrt;
Inisialisasi variable diatas adalah mutex = 1, wrt = 1, readcount = 0.
Struktur proses writer adalah
wait(wrt);
menulis
signal(wrt);
Sedangkan struktur proses reader adalah
wait(mutex);
readcount++;
if (readcount == 1)
wait(rt);
signal(mutex);
membaca
wait(mutex);
readcount--;
if (readcount == 0)
signal(wrt);
signal(mutex):
c. Dining phil0s0pher pr0blem
Struktur data yang digunakan untuk penyelesaian permasalahan ini dengan semaphore
adalah
semaphore chopstick[5];
Dimana semua nilai array dinisialisasi 1. Struktur program untuk filosof ke i adalah
do {
wait(chopstick[i])
wait(chopstick[(i+1) % 5])
makan
signal(chopstick[i]);
signal(chopstick[(i+1) % 5]);
berfikir
} while (1);


Tidak ada komentar:

Posting Komentar