FUNGSI (FUNCTION) PADA C++
KONSEP DASAR Program komputer yang dibuat untuk menjawab permasalahan umumnya berukuran sangat besar. Pengalaman telah menunjukkan bahwa cara terbaik untuk mengembangkan dan menangani program besar adalah menyusunnya menjadi potongan-potongan potongan program yang berukuran kecilkecil (atau disebut modul) yang lebih mudah untuk ditangani dibanding dengan program yang terdiri dari banyak sekali baris. Teknik ini disebut conquer.
2
Fungsi adalah suatu bagian dari program yang dipergunakan untuk mengerjakan suatu tugas tertentu dan letaknya dipisahkan dari bagian program yang menggunakannya. Program dari bahasa C dibentuk dari kumpulan fungsi, yaitu: • Fungsi utama main() • Fungsi pustaka (standar) mis: printf(), printf scanf() • Fungsi yang dibuat sendiri oleh pemrogram
3
Penyebab seringnya penggunaan Fungsi: 1. Fungsi menjadikan program C mempunyai struktur yang jelas. Dengan memisahkan bagian detail dalam fungsi-fungsi, fungsi maka fungsi utama akan lebih pendek, jelas dan mudah dimengerti (struktur ( program yang baik). 2. Fungsi dapat digunakan untuk menghindari penulisan secara berulang-ulang. Bagian program yang membutuhkannya cukup memanggil fungsi yang telah tersedia, tanpa menulis ulang.
4
FUNGSI STANDAR Tabel berikut menyajikan daftar sebagian fungsi baku matematika yang sudah tersedia di dalam pustaka C dan siap untuk digunakan.
5
FILE HEADER Setiap pustaka baku mempunyai file header yang mengandung prototype fungsi untuk semua fungsi yang ada di dalam pustaka dan definisi dari tipe-tipe data maupun konstanta yang diperlukan oleh fungsi tersebut. Berikut dicantumkan daftar file header yang dapat di-include ke dalam program.
6
7
DEFINISI FUNGSI
Fungsi secara umum terdiri dari 2 buah komponen utama yakni definisi fungsi dan tubuh fungsi. • Bentuk umum suatu fungsi:
• Contoh definisi fungsi:
8
DEKLARASI FUNGSI
1. Diawali dengan fungsi utama (Prototype Fungsi) Fungsi
9
2. Diawali dengan fungsi yang lain
Apakah perbedaan antara ke-2 cara pendeklarasian tersebut? >> perlu diingat bahwa prinsip kerja program C sekuensial. Untuk alasan dokumentasiprogram yang baik, maka sebaiknya semua fungsi yang akan dipergunakan dideklarasikan terlebih dahulu (cara I). 10
JENIS FUNGSI
11
Contoh Penggunaan Fungsi Void & Non-void
12
Ruang Lingkup Variabel Ruang lingkup / scope variabel adalah batasan atau jangkauan suatu variabel di dalam fungsi. Terdapat 3 jenis scope variabel, yakni: Variabel Lokal, hanya dikenal di daerah lokal saja (mis: blok statement tertentu, di dalam fungsi) Contoh - 1:
13
Ruang Lingkup Variabel
14
/* File program : lokal.c */ #include <stdio.h> void fung_1(void); main() { int i = 20; fung_1(); printf("nilai i di dalam main() = %d\n", i); } void fung_1(void) { int i =11; int i 11; printf("nilai i di dalam fung_1() = %d\n", i); } Contoh eksekusi : nilai i di dalam fung_1() = 11 nilai i di dalam main() = 20
15
Ruang Lingkup Variabel • Variabel Global dikenal di seluruh daerah dalam program (baik di dalam ataupun di luar fungsi).
16
Contoh :
17
/* File program : ekstern1.c Contoh program dengan variabel eksternal */ #include <stdio.h> int i = 273; /* variabel eksternal */ void tambah(void); main() { printf("Nilai awal i = %d\n", i); i += 7; printf("Nilai i kini = %d\n", i); tambah(); printf("Nilai i kini=%d\n",i); tambah(); printf("Nilai i kini = %d\n", i); } void tambah(void) { i++; }
Contoh eksekusi : Nilai awal i = 273 Nilai i kini = 280 Nilai i kini = 281 Nilai i kini = 282
18
• Variabel Statik o Variabel yang nilainya tetap dipertahankan walaupun proses telah keluar dari bloknya. o Variabel statik dibuat dengan menggunakan modifier (pengubah) static o Variabel statik merupakan modifier dari variabel lokal atau global, sehingga variabel statik dapat bersifat statik lokal atau statik global (tergantung dari letak deklarasinya) deklarasinya
19
• Contoh
20
Argumen Fungsi • Disebut juga Parameter • Sebuah fungsi dapat mempunyai argument-argument yang bersifat opsionalbisa ada atau tidak • argument-argument berfungsi sebagai parameter inputan yang berupa variabel-variabel bagi fungsi tersebut(bersifat tersebut lokal, sehingga tidak perlu dideklarasikan lagi) • argument harus bertipe data tertentu 21
Terdapat 2 jenis parameter, yaitu: • Parameter Formal → parameter yang ditulis pada deklarasi fungsi • Parameter Aktual → parameter yang berlaku sebagai inputan dalam pemanggilan suatu fungsi → Dapat berupa variabel atau nilai tertentu atau suatu statement
22
Berdasarkan penjelasan di atas, maka komunikasi antar fungsi dilakukan dengan saling bertukar data, dengan cara: • hasil balik dari suatu fungsi (return) • dengan menggunakan variabel Global (bersifat ( global) • parameter aktual yang dikirimkan ke parameter formal
23
PEMANGGILAN FUNGSI : BY VALUE / BY REFERENCE • Ada dua cara pemrosesan fungsi dalam berbagai bahasa pemrograman, yaitu pemanggilan nilai (call by value) dan pemanggilan referensi (call by reference), yang keduanya mempunyai karakteristik berbeda. • Metode pemanggilan nilai terjadi jika yang dikirimkan ke fungsi oleh pemanggilnya adalah berupa nilai, dan tidak berpengaruh pada variable yang tertulis di dalam argument pemanggilnya argument pemanggilnya. • Sedangkan metode pemanggilan referensi terjadi jika yang dikirimkan ke fungsi berupa referensi (alamat) dan diterima oleh fungsi sehingga perubahan terhadap variable penerima ini akan mempengaruhi variable argument yang memanggilnya. 24
• Secara default pengiriman parameter di dalam adalah pass by value • Karakteristik dari pengiriman parameter secara nilai adalah: 1. Yang dikirimkan ke fungsi adalah nilainya, nilainya bukan alamat memori dari datanya 2. Fungsi yang menerima kiriman nilai ini akan menyimpannya di alamat yang terpisah dari nilai aslinya yang digunakan oleh bagian program yang memanggil fungsi tersebut 3. Karena alasan no.2 di atas, maka perubahan nilai difungsi tidak akan merubah (tidak mempengaruhi) pada nilai asli di bagian program yang memanggil fungsi walaupun keduanya menggunakan nama variabel yang sama 4. Pengiriman secara nilai adalah pengiriman searah, yaitu dari bagian program yang memanggil fungsi ke fungsi yang dipanggil 5. Pengiriman suatu nilai dapat dilakukan untuk suatu statement, tidak hanya untuk sebuah variabel atau array atau konstanta saja 25
• Contoh:
26
Penjelasan Contoh
Berdasarkan contoh di atas, maka pengiriman secara nilai dapat dijelaskan sebagai berikut: 1. Parameter aktual yang dikirimkan adalah berupa nilai datanya, yaitu untuk variabel data1, data1/5, dan data3; dalam statement: secaraNilai(data1,data ,data1/5,data3); 2. Variabel data1 dan data3 menempati memori yang berbeda untuk fungsi main() dan fungsi secaraNilai() • Fungsi main(), nilai variabel data1 disimpan pada alamat = 24A0 • Fungsi secaraNilai(), nilai variabel data1 disimpan pada alamat = 24AE 3. Perubahan nilai variabel data1 pada fungsi secaraNilai() secaraNilai menjadi bernilai = 100 tidak merubah nilai variabel data1 ini dalam fungsi main() yang akan tetap bernilai = 20 27
4. Pengiriman suatu nilai merupakan pengiriman satu arah sebagai berikut:
5. Pengiriman secara nilai dapat mengirimkan suatu statement, yaitu data1/5
28
FUNGSI REKURSIF
• Fungsi yang telah dibahas sebelumnya dipanggil dari bagian lain di luar tubuh fungsi yang bersangkutan. Fungsi rekursif adalah suatu fungsi yang memanggil dirinya sendiri artinya fungsi tersebut dipanggil di dalam tubuh fungsi itu sendiri. • Fungsi factorial, yang menghitung nilai factorial dari suatu bilangan bulat positif merupakan pokok bahasan yang memudahkan pemahaman fungsi rekursif. • Berikut adalah fungsi factorial yang diselesaikan dengan cara biasa: Int factorial(int n) { Int counter hasil=1; In For (counter = n; counter >= 1; counter--) Hasil *=counter; Return hasil; } 29
• Fungsi di atas menunjukkan bahwa nilai faktorial dihitung menggunakan looping sehingga melakukan proses sebagai berikut: berikut Hasil = 1; Hasil = hasil * n; artinya hasil = n; Hasil = hasil * (n-1) artinya hasil = n x (n-1); (n Demikian seterusnya sampain bernilai 1, atau jika dituliskan sekaligus menjadi : Factorial = n! = n x (n-1) x (n-2) 2) …. X 1; Fungsi ini dapat dituliskan dalam bentuk : Factorial (n) = n ! = n x (n-1)!;
30
Yang menunjukkan sifat rekursif dari suatu fungsi, yaitu (n-1)!. Oleh karena itu, fungsi factorial yang telah ditulis dalam program C sebelumnya, dapat ditulis kembali dalam bentuk rekursif sbb : Int factorial(int n) { If (n == 0) Return 1; Else Return (n * factorial(n-1)); } 31
Contoh lain adalah menghitung jumlah dari suatu deret fibonnaci, dimana deret tersebut didefinisikan sebagai: Fibonacci(0)= 0 Fibonacci(1) = 1 Fibonacci(n) = Fibonacci(n-1) 1) + Fibonacci(n-2) Fibonacci(n Sehingga fungsi dalam program C dapat dibuat sbb: Long Fibonacci(long n) { If(n==0|| n==1) Return n; Else Return Fibonacci(n-1) + Fibonacci(n-2); } 32
….SEE YOU NEXT WEEK Lilis Setyowati
33