Jumat, 25 Maret 2011

Pegurutan(TEKOM)

program pengurutan;
uses wincrt;

const
maks=100;
type
daf_urut=array[1..maks]of integer;
var
urut:daf_urut;
x,z,temp,data:integer;
procedure urut_maks;
begin
clrscr;
write('Urutan Maksimum = ');
for x:=1 to data do
begin
for z:=x to data do
begin
if urut[z]<urut[x]then
begin
temp:= urut[z];
urut[z]:=urut[x];
urut[x]:=temp;
end;
end;
write(urut[x],' ');
end;
writeln;
end;
procedure urut_min;
begin
write('Urutan Minimum = ');
for x:=1 to data do
begin
for z:=x to data do
begin
if urut[z]>urut[x]then
begin
temp:=urut[z];
urut[z]:=urut[x];
urut[x]:=temp;
end;
end;
write(urut[x],' ');
end;
end;

begin

write('banyak data = ');readln(data);
writeln('-----------------------');
for x:=1 to data do
begin
write('data ke-',x,' = ');readln(urut[x]);
end;
writeln;
writeln;
writeln('data setelah diurut : ');
writeln('------------------------');
urut_maks;
urut_min;
readln;
end.

Mesin Karakter (TEKOM)

program Mesin_Karakter;
uses wincrt;

type
number = set of '0'..'9';
character= set of CHAR;
small = set of 'a'..'z';
big = set of 'A'..'Z';
var
berkas :text;
gede :big;
alit :small;
nom :number;
abjd,tdbc,opr :character;
a, p, i, t, s, b,o , Counter :INTEGER;
Ch :CHAR;
NamaFile :string[80];
procedure panggilfile(NF:string);
begin
ASSIGN(berkas, NF);
RESET(berkas);
end;
procedure tutup;
begin
close(berkas);
end;
procedure analisa;
begin
gotoxy(18,8);WRITE('MASUKKAN NAMA FILE YG AKAN DI TAMPILKAN : ');
gotoxy(18,11);write('.........................................');
gotoxy(18,10);readln(NamaFile);
CLRSCR;
panggilfile(NamaFile);
WRITELN;gotoxy(18,3);
WRITELN('ISI DARI FILE ','" ',NamaFile,' "',' ADALAH :');
WRITELN;
Counter := 0;
a := 0;
p := 0;
i := 0;
t := 0;
s := 0;
b := 0;
o := 0;
alit := ['a'..'z'];
gede := ['A'..'Z'];
abjd := alit + gede;
nom := ['0'..'9'];
tdbc:= [',',';','-','''','.','!','?',')','(','"',':','_'];
opr := ['+','-','*','/','='];
WHILE NOT EOF(berkas) DO
BEGIN
WHILE NOT EOLN(berkas) DO
BEGIN
READ(berkas,Ch);
WRITE(Ch);
Counter := Counter + 1;
IF Ch IN abjd THEN
BEGIN
a := a + 1;
IF Ch IN alit THEN
i := i + 1
ELSE IF Ch IN gede THEN
p := p + 1
END
ELSE IF Ch IN nom THEN
t := t + 1
ELSE IF Ch IN tdbc THEN
s := s + 1
ELSE IF Ch IN opr THEN
b := b + 1
ELSE
o := o + 1
END;
readln(berkas);
writeln
END;
tutup;
end;
procedure hasil;
begin
WRITELN;
gotoxy(15,9); WRITELN('###############################');
gotoxy(15,10);WRITELN(' Jumlah Huruf Kecil = ', i:5);
gotoxy(15,11);WRITELN(' Jumlah Huruf Kapital = ', p:5);
gotoxy(15,12);WRITELN('-------------------------------+');
gotoxy(15,13);WRITELN('1. JUMLAH HURUF = ', a:4);
gotoxy(15,14);WRITELN('-------------------------------');
gotoxy(15,15);WRITELN('2. JUMLAH BILANGAN ANGKA = ', t:4);
gotoxy(15,16);WRITELN('3. JUMLAH TANDA BACA = ', s:4);
gotoxy(15,17);WRITELN('4. JUMLAH OPERATOR MATEMATIKA = ', b:4);
gotoxy(15,18);WRITELN('5. JUMLAH SPASI = ', o:4);
gotoxy(15,19);WRITELN('###############################--------');
gotoxy(15,20);WRITELN(' TOTAL KARAKTER = ', Counter:5);
WRITELN;
end;
VAR Ul:char;
begin
REPEAT
CLRSCR;
analisa;
hasil;GOTOXY(15,22);
Write('Mau Ulang Lagi [Y/T]: ');Ul:=Upcase(Readkey);
Until Ul<>'Y';
END.

Senin, 31 Januari 2011

Tugas Sistem Operasi 2

MANAJEMEN MEMORI
PEMUATAN adalah Salah satu bagian sistem operasi yang mempengaruhi dalam menentukan proses mana yang diletakkan pada antrian.
Tanda pengenal untuk pencarian letak memori adalah alamat, lintasan / trek, sector pada suatu disk.

Fungsi manajemen memori :
• Mengelola informasi yang dipakai dan tidak dipakai.
• Mengalokasikan memori ke proses yang memerlukan.
• Mendealokasikan memori dari proses telah selesai.
• Mengelola swapping atau paging antara memori utama dan disk

Memori Dukung / backing store
Contohnya : Floppy, Harddisk, CD, dll.
Untuk mendukung memori kerja, umumnya berbentuk disk sehingga berlaku juga asas pemuktakhiran. Setiap trek dan sektor dapat menyimpan sejumlah byte dari memori kerja. Memori kerja dicapai melalui alamat memori dan register data memori. Dan untuk mencapai informasi di memori dukung, isinya harus dipindahkan dulu ke memori kerja (memori dukung = memori semu = virtual memori).
1 pindahan = 1 blok, makin kecil ukuran memori kerja, makin sering terjadi pindahan.


Alamat Memori
- Alamat memori mutlak (alamat fisik)
Sel memori pada memori kerja adalah sumber daya berbentuk fisik, sehingga untuk mencapai sel memori ini digunakan kata pengenal. Maka disebutlah alamat fisik dan karena nomor alamat fisik ini bersifat mutlak (nomor setiap sel adalah tetap), maka disebut juga alamat mutlak.

- Alamat memori relatif (alamat logika)
Alamat memori yang digunakan oleh program / data berurutan / berjulat. Jika kita menggunakan alamat 1, maka kitapun menggunakan alamat 2,3, … dan untuk 1 informasi jika alamat awalnya 0 dan alamat lainnya relatif terhadap alamat awal 0 ini, maka dinamakan alamat relatif. Dan alamat tersebut adalah logika dari untaian alamat yang menyimpan informasi maka dikenal alamat memori logika.
Contoh : alamat awal relatif 0, alamat awal fisik 14726, maka selisihnya = relokasinya = 14726-0 = 14726.

PEMUATAN INFORMASI KE MEMORI
Ada beberapa cara pemuatan informasi ke ruang memori, yaitu:
~ Pemuatan mutlak
~ Pemuatan relokasi
~ Pemuatan sambung
~ Pemuatan dinamik

1. Pemuatan Mutlak

Pemuatan informasi ke memori-kerja, alamat yangtercantum di dalam tata olah sama dengan alamat yangditempatinya di dalam memori-kerja.
Contohnya pada program, alamat awal 5235 dan subroutine = 5468 diletakkan pada alamat fisik yang sama.
2. Pemuatan Relokasi

Kondisi dimana pemuatan informasi ke memory-kerja,alamat yang tercantum di dalam tataolah tidak mestisama dengan alamat yang ditempatinya di dalammemori-kerja.
Contohnya alamat pangkal / fisik = 14200, alamat relative program 327, maka alamat mutlaknya = 14200 + 327 = 14527

Hubungan antara alamat memori mutlak dan alamat relative

Hubungan alamat memori mutlak dan alamat relatif berbeda sebanyak alamat pangkal pada alamat mutlak dikurangi dengan alamat awal pada alamat relatif, selisih ini dinamakan Relokasi Secara umum, kalau alamat awal adalah A, alamat pangkal
adalah P, maka relokasi P adalah sebesar:
R = P – A

3. Pemuatan Sambung (linker)

Menyambungkan suatu informasi ke informasi lain di dalam memori-kerja. Pemuatan sambung sering digunakan pada tata olah atau penggalan tata olah yang tersimpan di dalam pustaka (library).
Contohnya : informasi alamat akhir dari bagian informasi yang akan disambung tersebut.


4. Pemuatan dinamik (pemuatan tumpang atauoverlay)

Jika ukuran tataolah itu melampaui ukuran ruang memori-kerja, tataolah dapat dipenggal ke dalam sejumlah segmen. Segmen itulah yang kemudian dimuat ke dalam memori-kerja. Pelaksanaan pekerjaan berlagsung segmen demi segmen