Pengantar Teknik Kompilasi

Slides:



Advertisements
Presentasi serupa
Oleh : Suparno Blog : Programming Language Pengen. Pengel. Data Elektronik.
Advertisements

1 BAHASA PEMROGRAMAN Sususan kata / kalimat untuk memberikan intruksi kepada mesin.
TEKNIK KOMPILASI By Kustanto, S.T.,M.Eng.
Pengayaan Software/Hardware dan Pengantarmukaan
Komunikasi Dasar Manusia dan Komputer
Teknik Kompilasi Febuari 2013.
Pengantar Teknologi Informasi
PEMROGRAMAN TERSTRUKTUR
PENGANTAR ALGORITMA PUTRA PRIMA NAUFAL, S.ST masputra.net.
TEKNIK KOMPILASI.
Bahasa Tingkat Tinggi.
Perkembangan Bahasa.
Analisis Semantik.
KOMPILASI KOMPILATOR (COMPILER) adalah :
SOFTWARE PENDUKUNG DAN PENGOPERASIAN SISTEM INFORMASI
Bahasa Pemrograman Tingkat Tinggi
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
Pengantar Teknik Kompilasi
PERANGKAT LUNAK (SOFTWARE)
Pertemuan 1 & 2 Pendahuluan
Algoritma dan Pemrograman
Rifky Kurniawan, S.Kom, MTI
Pengantar Teknik Kompilasi
TEKNIK KOMPILASI.
PERANGKAT LUNAK Software.
MODEL KOMPILATOR FUNGSI UMUM BAGIAN KOMPILATOR Dosen Pengampu:
FUNGSI UMUM BAGIAN KOMPILATOR Dosen Pengampu: Istiqomah, s.kom
PENGANTAR TEKNIK KOMPILASI
Teknik Kompilasi “Translator”
Pengantar Teknologi Informasi (Teori)
BAB 1 BAHASA PEMROGRAMAN
BAHASA PEMROGRAMAN TERSTRUKTUR
ALGORITMA & PEMROGRAMAN
BAHASA PEMROGRAMAN.
Analisa Semantik, Kode Antara,
Analisis semantik, kode antara dan pembangkitan kode
Pesan-pesan kesalahan
Pengantar Teknik Kompilasi
MODEL KOMPILATOR FUNGSI UMUM BAGIAN KOMPILATOR Dosen Pengampu:
Pengantar Teknik Kompilasi
Semantics Analyser Contoh : A := ( A+B) * (C+D)
DASAR PEMROGRAMAN KOMPUTER
Analisa Semantik, Kode Antara,
Pertemuan 1.
Teknik Kompilasi “Translator”
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
DASAR PEMROGRAMAN KOMPUTER
TEORI BAHASA & OTOMATA (PENGENALAN KOMPILASI)
Proses kompilasi COMPILATOR.
Keterampilan komputer 1AB
Dasar-dasar Pemrograman
ALGORITMA & PEMROGRAMAN
Lecturer Note II Turbo Pascal & Pemrograman
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
Pengantar Teknologi Informasi
Pengantar Teknologi Informasi
TEKNIK KOMPILASI PERTEMUAN II.
Pengantar Teknologi Informasi
Teknik Kompilasi Abdul Wahid, ST, M.Kom
TEKNIK KOMPILASI Pertemuan III.
Pengenalan Kompilasi & Klasifikasi Tatabahasa Formal menurut Chomsky
Pengantar Teknik Kompilasi
Ilustrasi Proses Kompilasi
Pengantar Teknik Kompilasi
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
Semantics Analyser by Kustanto
Dasar Pemrograman Pengenalan Nurul Anisa Sri Winarsih, M. CS
Pengantar Teknologi Informasi
ANALISIS SEMANTIK, KODE ANTARA, DAN PEMBANGKITAN KODE
Transcript presentasi:

Pengantar Teknik Kompilasi Pendahuluan Tujuan Pembelajaran : Mahasiswa memahami cara kerja serta proses yang terjadi pada sebuah Compiler Mahasiswa memahami konsep pembuatan sebuah Compiler Mahasiswa mengetahui bagaimana sebuah bahasa pemrograman dapat diterjemahkan oleh mesin. Metari Pembelajaran Bentuk-bentuk karakter dan kelas Grammar. Ekspresi Regular dan Automata Analisa Leksikal sebagai tahap awal kompilasi Analisa Sintaks, bentuk-bentuk derivasi serta implementasi parsing. Analisa Semantik dan tahapan Sintesa. Penanganan kesalahan kompilasi dan fungsi tabel informasi. Pendahuluan

Arti Kata Teknik Kompilasi Teknik adalah suatu metode atau cara Kompilasi suatu proses menggabungkan serta menterjemahkan sesuatu (source program) menjadi bentuk lain Compile: menterjemahkan sebuah program yang ditulis dalam bahasa pemrograman tingkat tinggi ke bahasa mesin Pendahuluan

Kenapa Perlu Translator? Bagi user yang hanya pengguna mungkin kata-kata translator adalah membingungkan. Kenapa perlu translator? Pertanyaan tsb akan membingungkan bagi programmer yang membuat program dengan bahasa mesin Pendahuluan

Latar Belakang Bahasa mesin adalah bentuk bahasa terendah pada komputer, kita dapat berhubungan/komunikasi langsung dengan bagian-bagian yang ada di dalam komputer seperti bits, register dan sangat primitif. Bahasa mesin adalah tidak lebih dari urutan bit-bit 0 dan 1 Instruksi dalam bahasa mesin bisa saja dibentuk menjadi micro-code, semacam prosedur dalam bahasa mesin Pendahuluan

Bagaimana dengan orang yang tidak mengerti bahasa mesin? Bagi user yang tidak mengerti bahasa mesin akan mengalami masalah. Hal ini disebabkan karena mereka harus belajar dahulu bahasa mesin, dan akan bergabung pada jenis mesin komputer yang digunakan. Jika jenis komputer mengalami perubahan maka dapat dipastikan bahwa user harus mempelajari lagi bahasa mesin dengan jenis komputer yang baru. Pendahuluan

Bagaimana dengan orang yang tidak mengerti bahasa mesin? Oleh karena itu manusia berusaha dan menciptakan suatu bahasa yang dapat dimengerti baik oleh manusia maupun oleh komputer. Bahasa yang demikian ini sering disebut dengan bahasa tingkat tinggi. Pendahuluan

Bagaimana dengan orang yang tidak mengerti bahasa mesin? Untuk era sekarang user tidak lagi banyak dipusingkan mengenai penterjema karena kemudahan-kemudahan yang diberikan oleh bahasa tingkat tinggi sekarang sangatlah memudahkan dan lebih fleksibel dalam bekerja pada mesin-mesin komputer yang berbeda. Pendahuluan

Pengantar Teknik Kompilasi 1. Bahasa Pemrograman Bahasa mesin Bahasa Assembly Bahasa Pemrograman Bahasa Tingkat tinggi Bahasa Problem Oriented Pendahuluan

Pengantar Teknik Kompilasi Bahasa tingkat tinggi (user oriented) lebih banyak memberikan fungsi kontrol program, kalang, block, dan prosedur. Bahasa mesin merupakan bentuk terendah dari bahasa komputer. Instruksi direpresentasikan dalam kode numerik. Program Language Bahasa problem oriented sering juga dimasukkan sebagai bahasa tingkat tinggi, misalnya SQL, Myob, dsb. Bahasa Assembly merupakan bentuk simbolik dari bahasa mesin. Kode misalnya ADD, MUL, dsb Pendahuluan

Bahasa Tingkat Tinggi Bahasa yang lebih dikenal oleh manusia, maksudnya adalah statement yang digunakan menggunakan bahasa yang dipakai oleh manusia (Inggris) Programmudah untuk dikoreksi dan diperbaiki (debug) Tidak tergantung pada salah satu jenis mesin komputer Bahasa tingkat tinggi biasanya masih membutuhkan translator Pendahuluan

Bahasa Tingkat Tinggi Memberikan fasilitas yang lebih banyak, seperti struktur kontrol program yang terstruktur, memiliki blok-blok, serta prosedur dan fungsi-fungsi: Struktur kontrol seperti: kondisi (If ...Then...Else), perulangan (For, While) struktur blok (begin...End, {...}) Pendahuluan

Bahasa Tingkat Tinggi Oleh karena itu dari bahasa tingkat tinggi ke dalam bahasa mesin dibutuhkan sesuatu untuk menterjemahkan agar mesin (komputer) mengerti apa yang diinginkan manusia. Menerjemahkan statement bahasa tingkat tinggi ke dalam bahasa tingkat rendah dapat dibedakan menjadi dua; melalui interpreter atau compiler yang fungsinya sama yaitu menerjemahkan Pendahuluan

Pengantar Teknik Kompilasi 2. Translator Translator melakukan pengubahan source code / source program ke dalam target code / object code Interpreter dan Compiler termasuk dalam kategori translator. Interpreter Translator Tidak membangkitkan object code Source code dan data diproses bersamaan Contoh, BASICA, SPSS, DBASE III Assembler Compiler Source Code adalah bahasa tingkat tinggi. Object Code adalah bahasa mesin atau assembly Source code dan data diproses tidak bersamaan Contoh, PASCAL, C Source Code adalah bahasa Assembly Object Code adalah bahasa mesin Contoh, Turbo Assembler Pendahuluan

Pengantar Teknik Kompilasi Interpreter Penanganan Kesalahan Program Sumber Analisa Leksikal Analisa Sintaks Intermediate Program Interpretasi Hasil Operasi Pengelolaan Tabel Pendahuluan

Pengantar Teknik Kompilasi Assembler Source Code Assembler Object Code Lingker File Target .ASM .OBJ .EXE / .COM Proses Sebuah Kompilasi pada Bahasa Assembler Source Code adalah bahasa Assembler, Object Code adalah bahasa mesin Object Code dapat berupa file object (.OBJ), file .EXE, atau file .COM Contoh : Turbo Assembler (dari IBM) dan Macro Assembler (dari Microsoft) Pendahuluan

Pengantar Teknik Kompilasi Compiler Definisi : Kompilator (compiler) adalah sebuah program yang membaca suatu program yang ditulis Dalam suatu bahasa sumber (source language) dan menterjemahkannya kedalam suatu bahasa sasaran (target language) Proses kompilasi dapat digambarkan melalui sebuah blok diagram sebagai berikut : Compiler Program sumber Bahasa sasaran Pesan-pesan kesalahan (error messages) Proses Kompilasi dikelompokkan kedalam dua kelompok besar : 1. Analisa : Program sumber dipecah-pecah dan dibentuk menjadi bentuk antara (Intermediate Representation ) 2. Sintesa : Membangun program sasaran yang diinginkan dari bentuk antara Pendahuluan

Bagan pokok proses kompilasi Pengantar Teknik Kompilasi Blok Diagram Program Sumber Program Sasaran ANALISA SINTESA Penganalisa Semantik Pembangkit Kode antara Penganalisa Leksikal (scanner) Penganalisa Sintaks (parser) Pembentuk kode Pengoptimal kode TABEL SIMBOL Bagan pokok proses kompilasi Pendahuluan

Pengantar Teknik Kompilasi Keterangan 1. Program Sumber ditulis dalam bahasa sumber, misal Pascal, Assembler, dsb 2. Program Sasaran dapat berupa bahasa pemrograman lain atau bahasa mesin pada suatu komputer 3. Scanner : Memecah program sumber menjadi besaran leksik/token 4. Parser : Memeriksa kebenaran dan urutan kemunculan token 5. Penganalisa semantik : Melakukan analisa semantik, biasanya dalam realisasi akan digabungkan Dengan intermediate code generator (bagian yang berfungsi membangkitkan kode antara) 6. Pembentuk Kode : Membangkitkan kode objek 7. Pengoptimal Kode : Memperkecil hasil dan mempercepat proses 8. Tabel : Menyimpan semua informasi yang berhubungan dengan proses kompilasi Pendahuluan

Pengantar Teknik Kompilasi Library Object Code Source Code 1 Compiler 1 Object Code 1 Source Code 2 Compiler 2 Object Code 2 Executable Lingker Source Code n Compiler n Object Code n Pembentukan file Executable berdasar dari beberapa Source Code Source Code dapat terdiri dari satu atau lebih behasa pemrograman. Pendahuluan

Pengantar Teknik Kompilasi Pembuatan Compiler Pembuatan kompilator dapat dilakukan dengan : Bahasa Mesin Tingkat kesulitannya tinggi, bahkan hampir mustahil dilakukan sangat tergantung pada mesin 2. Bahasa Assembly Bahasa Assembly bisa dan biasa digunakan sebagai tahap awal pada proses pembuatan sebuah kompilator Hasil dari program mempunyai ukuran yang relatif kecil Sulit dimengerti karena perintahnya singkat-singkat, butuh usaha yang besar untuk membuat compiler dengan bahasa ini Pendahuluan

Pengantar Teknik Kompilasi Pembuatan Compiler Pembuatan kompilator dapat dilakukan dengan : Bahasa Tingkat Tinggi lain pada ,mesin yang sama Proses pembuatan kopilator akan lebih mudah Fasilitas yang dimiliki lebih baik (banyak) Memiliki ukuran yang relatif besar, misal membuat compiler pascal dengan menggunakan bahasa C Untuk mesin yang berbeda perlu dikembangkan tahapan-tahapan tambahan. Misal membuat compiler C pada Dos berdasarkan compiler C pada unix Bootstrap Pembuatan kompilator secara bertingkat. P1 P2 P0 Pendahuluan