Pemrograman Fungsional - Panduan Cepat

Bahasa pemrograman fungsional dirancang khusus untuk menangani komputasi simbolik dan aplikasi pemrosesan daftar. Pemrograman fungsional didasarkan pada fungsi matematika. Beberapa bahasa pemrograman fungsional yang populer antara lain: Lisp, Python, Erlang, Haskell, Clojure, dll.

Bahasa pemrograman fungsional dikategorikan menjadi dua kelompok, yaitu -

  • Pure Functional Languages- Jenis bahasa fungsional ini hanya mendukung paradigma fungsional. Misalnya - Haskell.

  • Impure Functional Languages- Jenis bahasa fungsional ini mendukung paradigma fungsional dan gaya pemrograman imperatif. Misalnya - LISP.

Pemrograman Fungsional - Karakteristik

Karakteristik yang paling menonjol dari pemrograman fungsional adalah sebagai berikut -

  • Bahasa pemrograman fungsional dirancang berdasarkan konsep fungsi matematika yang menggunakan ekspresi kondisional dan rekursi untuk melakukan komputasi.

  • Mendukung pemrograman fungsional higher-order functions dan lazy evaluation fitur.

  • Bahasa pemrograman fungsional tidak mendukung Kontrol aliran seperti pernyataan loop dan pernyataan bersyarat seperti Pernyataan If-Else dan Switch. Mereka secara langsung menggunakan fungsi dan panggilan fungsional.

  • Seperti OOP, bahasa pemrograman fungsional mendukung konsep populer seperti Abstraksi, Enkapsulasi, Warisan, dan Polimorfisme.

Pemrograman Fungsional - Keuntungan

Pemrograman fungsional menawarkan keuntungan berikut -

  • Bugs-Free Code - Pemrograman fungsional tidak mendukung state, jadi tidak ada hasil efek samping dan kami dapat menulis kode bebas kesalahan.

  • Efficient Parallel Programming- Bahasa pemrograman fungsional TIDAK memiliki status yang dapat diubah, jadi tidak ada masalah perubahan status. Seseorang dapat memprogram "Fungsi" untuk bekerja secara paralel sebagai "instruksi". Kode tersebut mendukung penggunaan kembali dan kemudahan pengujian yang mudah.

  • Efficiency- Program fungsional terdiri dari unit independen yang dapat berjalan secara bersamaan. Hasilnya, program semacam itu lebih efisien.

  • Supports Nested Functions - Pemrograman fungsional mendukung Fungsi Nested.

  • Lazy Evaluation - Pemrograman fungsional mendukung Konstruksi Fungsional Malas seperti Daftar Malas, Peta Malas, dll.

Sebagai kekurangannya, pemrograman fungsional membutuhkan ruang memori yang besar. Karena tidak memiliki status, Anda perlu membuat objek baru setiap kali melakukan tindakan.

Pemrograman Fungsional digunakan dalam situasi di mana kita harus melakukan banyak operasi yang berbeda pada kumpulan data yang sama.

  • Lisp digunakan untuk aplikasi kecerdasan buatan seperti Pembelajaran mesin, pemrosesan bahasa, Pemodelan ucapan dan penglihatan, dll.

  • Penerjemah Lisp yang disematkan menambahkan kemampuan program ke beberapa sistem seperti Emacs.

Pemrograman Fungsional vs. Pemrograman Berorientasi Objek

Tabel berikut menyoroti perbedaan utama antara pemrograman fungsional dan pemrograman berorientasi objek -

Pemrograman Fungsional OOP
Menggunakan data yang tidak dapat diubah. Menggunakan data yang dapat berubah.
Mengikuti Model Pemrograman Deklaratif. Mengikuti Model Pemrograman Imperatif.
Fokus pada: "Apa yang Anda lakukan" Fokus pada "Bagaimana kabar Anda"
Mendukung Pemrograman Paralel Tidak cocok untuk Pemrograman Paralel
Fungsinya tidak memiliki efek samping Metodenya dapat menghasilkan efek samping yang serius.
Kontrol Aliran dilakukan menggunakan panggilan fungsi & panggilan fungsi dengan rekursi Kontrol aliran dilakukan dengan menggunakan loop dan pernyataan bersyarat.
Ini menggunakan konsep "Rekursi" untuk mengulang Data Pengumpulan. Ini menggunakan konsep "Loop" untuk mengulang Data Pengumpulan. Misalnya: Untuk-setiap loop di Java
Urutan eksekusi pernyataan tidak begitu penting. Urutan eksekusi pernyataan sangat penting.
Mendukung "Abstraksi atas Data" dan "Abstraksi atas Perilaku". Hanya mendukung "Abstraksi atas Data".

Efisiensi Kode Program

Efisiensi kode pemrograman berbanding lurus dengan efisiensi algoritmik dan kecepatan eksekusi. Efisiensi yang baik memastikan kinerja yang lebih tinggi.

Faktor-faktor yang mempengaruhi efisiensi program meliputi -

  • Kecepatan mesin
  • Kecepatan penyusun
  • Sistem operasi
  • Memilih bahasa Pemrograman yang tepat
  • Cara data dalam suatu program diatur
  • Algoritma digunakan untuk memecahkan masalah tersebut

Efisiensi bahasa pemrograman dapat ditingkatkan dengan melakukan tugas-tugas berikut -

  • Dengan menghapus kode yang tidak perlu atau kode yang masuk ke pemrosesan yang berlebihan.

  • Dengan memanfaatkan memori optimal dan penyimpanan nonvolatile

  • Dengan memanfaatkan komponen yang dapat digunakan kembali jika memungkinkan.

  • Dengan memanfaatkan kesalahan & pengecualian penanganan di semua lapisan program.

  • Dengan membuat kode pemrograman yang menjamin integritas dan konsistensi data.

  • Dengan mengembangkan kode program yang sesuai dengan alur dan logika desain.

Kode pemrograman yang efisien dapat mengurangi konsumsi sumber daya dan waktu penyelesaian sebanyak mungkin dengan risiko minimum terhadap lingkungan operasi.

Dalam istilah pemrograman, a functionadalah sekumpulan pernyataan yang melakukan tugas tertentu. Fungsi menerima data, memprosesnya, dan mengembalikan hasil. Fungsi ditulis terutama untuk mendukung konsep usabilitas. Setelah fungsi ditulis, fungsi tersebut dapat dipanggil dengan mudah, tanpa harus menulis kode yang sama berulang kali.

Bahasa fungsional yang berbeda menggunakan sintaks yang berbeda untuk menulis fungsi.

Prasyarat untuk Menulis Fungsi

Sebelum menulis sebuah fungsi, seorang programmer harus mengetahui poin-poin berikut -

  • Tujuan fungsi harus diketahui oleh programmer.

  • Algoritma dari fungsi tersebut harus diketahui oleh programmer.

  • Variabel data fungsi & tujuannya harus diketahui oleh programmer.

  • Data fungsi harus diketahui pemrogram yang dipanggil oleh pengguna.

Kontrol Aliran dari suatu Fungsi

Ketika suatu fungsi "dipanggil", program "mentransfer" kontrol untuk menjalankan fungsi tersebut dan "aliran kontrolnya" adalah seperti di bawah ini -

  • Program mencapai pernyataan yang berisi "pemanggilan fungsi".

  • Baris pertama di dalam fungsi dijalankan.

  • Semua pernyataan di dalam fungsi dieksekusi dari atas ke bawah.

  • Ketika fungsi berhasil dijalankan, kontrol kembali ke pernyataan tempat dimulainya.

  • Setiap data yang dihitung dan dikembalikan oleh fungsi digunakan sebagai pengganti fungsi di baris kode asli.

Sintaks dari suatu Fungsi

Sintaks umum suatu fungsi terlihat sebagai berikut -

returnType functionName(type1 argument1, type2 argument2, . . . ) {     
   // function body 
}

Mendefinisikan Fungsi di C ++

Mari kita ambil contoh untuk memahami bagaimana suatu fungsi dapat didefinisikan dalam C ++ yang merupakan bahasa pemrograman berorientasi objek. Kode berikut memiliki fungsi yang menambahkan dua angka dan memberikan hasilnya sebagai keluaran.

#include <stdio.h> 

int addNum(int a, int b);     // function prototype  

int main() {    
   int sum; 
   sum = addNum(5,6);         // function call 
   printf("sum = %d",sum); 
   return 0; 
}  
int addNum (int a,int b) {    // function definition      
   int result; 
   result = a + b; 
   return result;             // return statement 
}

Ini akan menghasilkan keluaran sebagai berikut -

Sum = 11

Mendefinisikan Fungsi di Erlang

Mari kita lihat bagaimana fungsi yang sama dapat didefinisikan di Erlang, yang merupakan bahasa pemrograman fungsional.

-module(helloworld).  
-export([add/2,start/0]).   

add(A,B) ->
   C = A + B,  
   io:fwrite("~w~n",[C]).  
start() ->  
   add(5,6).

Ini akan menghasilkan keluaran sebagai berikut -

11

Prototipe Fungsi

Prototipe fungsi adalah deklarasi fungsi yang menyertakan tipe-balik, nama-fungsi & daftar-argumen. Mirip dengan definisi fungsi tanpa fungsi-tubuh.

For Example - Beberapa bahasa pemrograman mendukung prototyping fungsi & beberapa tidak.

Di C ++, kita bisa membuat prototipe fungsi dari fungsi 'sum' seperti ini -

int sum(int a, int b)

Note - Bahasa pemrograman seperti Python, Erlang, dll tidak mendukung prototyping fungsi, kita perlu mendeklarasikan fungsi lengkapnya.

Apa gunanya prototipe fungsi?

Prototipe fungsi digunakan oleh penyusun ketika fungsi tersebut dipanggil. Compiler menggunakannya untuk memastikan tipe kembalian yang benar, daftar argumen yang tepat diteruskan, & tipe kembaliannya benar.

Fungsi Tanda Tangan

Sebuah tanda tangan fungsi mirip dengan prototipe fungsi di mana jumlah parameter, tipe data parameter & urutan tampilan harus dalam urutan yang sama. Sebagai Contoh -

void Sum(int a, int b, int c);         // function 1  
void Sum(float a, float b, float c);   // function 2  
void Sum(float a, float b, float c);   // function 3

Function1 dan Function2 memiliki tanda tangan yang berbeda. Function2 dan Function3 memiliki tanda tangan yang sama.

Note - Function overloading dan Function overriding yang akan kita bahas pada bab-bab selanjutnya didasarkan pada konsep tanda tangan fungsi.

  • Kelebihan fungsi dapat dilakukan jika kelas memiliki beberapa fungsi dengan nama yang sama tetapi tanda tangan berbeda.

  • Penimpaan fungsi dimungkinkan jika fungsi kelas turunan memiliki nama dan tanda tangan yang sama dengan kelas dasarnya.

Fungsi terdiri dari dua jenis -

  • Fungsi standar
  • Fungsi yang ditentukan pengguna

Pada bab ini, kita akan membahas secara detail tentang fungsi.

Fungsi Standar

Ini adalah fungsi yang dibangun ke dalam Bahasa untuk melakukan operasi & disimpan di Standard Function Library.

For Example - 'Strcat' di C ++ & 'concat' di Haskell digunakan untuk menambahkan dua string, 'strlen' di C ++ & 'len' dengan Python digunakan untuk menghitung panjang string.

Program untuk mencetak panjang string dalam C ++

Program berikut menunjukkan bagaimana Anda dapat mencetak panjang string menggunakan C ++ -

#include <iostream> 
#include <string.h> 
#include <stdio.h> 
using namespace std;  

int main() {     
   char str[20] = "Hello World"; 
   int len; 
   len = strlen(str); 
   cout<<"String length is: "<<len; 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

String length is: 11

Program untuk mencetak panjang string dengan Python

Program berikut menunjukkan cara mencetak panjang string menggunakan Python, yang merupakan bahasa pemrograman fungsional -

str = "Hello World"; 
print("String length is: ", len(str))

Ini akan menghasilkan keluaran sebagai berikut -

('String length is: ', 11)

Fungsi yang Ditentukan Pengguna

Fungsi yang ditentukan pengguna ditentukan oleh pengguna untuk melakukan tugas tertentu. Ada empat pola berbeda untuk mendefinisikan suatu fungsi -

  • Fungsi tanpa argumen dan nilai pengembalian
  • Fungsi tanpa argumen kecuali nilai kembalian
  • Berfungsi dengan argumen tetapi tidak ada nilai kembali
  • Fungsi dengan argumen dan nilai kembali

Fungsi tanpa argumen dan nilai pengembalian

Program berikut menunjukkan bagaimana mendefinisikan sebuah fungsi tanpa argumen dan tanpa nilai kembali C++ -

#include <iostream> 
using namespace std; 

void function1() { 
   cout <<"Hello World"; 
}  
int main() { 
   function1(); 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Hello World

Program berikut menunjukkan bagaimana Anda dapat mendefinisikan fungsi serupa (tanpa argumen dan tanpa nilai pengembalian) di Python -

def function1():    
   print ("Hello World") 
    
function1()

Ini akan menghasilkan keluaran sebagai berikut -

Hello World

Fungsi tanpa argumen kecuali nilai kembalian

Program berikut ini menunjukkan bagaimana mendefinisikan sebuah fungsi tanpa argumen tetapi nilai yang dikembalikan dalam C++ -

#include <iostream> 
using namespace std; 
string function1() { 
   return("Hello World"); 
}  

int main() { 
   cout<<function1(); 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Hello World

Program berikut menunjukkan bagaimana Anda dapat mendefinisikan fungsi serupa (tanpa argumen tetapi nilai kembalian) di Python -

def function1(): 
   return "Hello World" 
res = function1() 
print(res)

Ini akan menghasilkan keluaran sebagai berikut -

Hello World

Berfungsi dengan argumen tetapi tidak ada nilai kembali

Program berikut menunjukkan bagaimana mendefinisikan fungsi dengan argumen tetapi tidak ada nilai yang dikembalikan C++ -

#include <iostream> 
using namespace std; 
void function1(int x, int y) {    
   int c; 
   c = x+y;  
   cout<<"Sum is: "<<c; 
}  

int main() { 
   function1(4,5); 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Sum is: 9

Program berikut menunjukkan bagaimana Anda dapat mendefinisikan fungsi serupa di Python -

def function1(x,y): 
   c = x + y 
   print("Sum is:",c) 
function1(4,5)

Ini akan menghasilkan keluaran sebagai berikut -

('Sum is:', 9)

Fungsi dengan argumen dan nilai kembali

Program berikut menunjukkan bagaimana mendefinisikan sebuah fungsi dalam C ++ tanpa argumen kecuali nilai yang dikembalikan -

#include <iostream> 
using namespace std; 
int function1(int x, int y) {    
   int c; 
   c = x + y;  
   return c;    
} 

int main() {  
   int res; 
   res = function1(4,5); 
   cout<<"Sum is: "<<res; 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Sum is: 9

Program berikut menunjukkan bagaimana mendefinisikan fungsi serupa (dengan argumen dan nilai kembali) di Python -

def function1(x,y): 
   c = x + y 
   return c  

res = function1(4,5) 
print("Sum is ",res)

Ini akan menghasilkan keluaran sebagai berikut -

('Sum is ', 9)

Setelah mendefinisikan sebuah fungsi, kita perlu memasukkan argumen ke dalamnya untuk mendapatkan keluaran yang diinginkan. Sebagian besar bahasa pemrograman mendukungcall by value dan call by reference metode untuk meneruskan argumen ke dalam fungsi.

Dalam bab ini, kita akan belajar "panggilan berdasarkan nilai" bekerja dalam bahasa pemrograman berorientasi objek seperti C ++ dan bahasa pemrograman fungsional seperti Python.

Dalam metode Panggil dengan Nilai, file original value cannot be changed. Ketika kita mengirimkan argumen ke suatu fungsi, itu disimpan secara lokal oleh parameter fungsi dalam memori tumpukan. Oleh karena itu, nilai diubah di dalam fungsi saja dan tidak akan berpengaruh di luar fungsi.

Panggilan dengan Nilai di C ++

Program berikut menunjukkan bagaimana Call by Value bekerja di C ++ -

#include <iostream> 
using namespace std; 

void swap(int a, int b) {    
   int temp; 
   temp = a; 
   a = b; 
   b = temp; 
   cout<<"\n"<<"value of a inside the function: "<<a; 
   cout<<"\n"<<"value of b inside the function: "<<b; 
}  
int main() {     
   int a = 50, b = 70;   
   cout<<"value of a before sending to function: "<<a; 
   cout<<"\n"<<"value of b before sending to function: "<<b; 
   swap(a, b);  // passing value to function 
   cout<<"\n"<<"value of a after sending to function: "<<a; 
   cout<<"\n"<<"value of b after sending to function: "<<b; 
   return 0;   
}

Ini akan menghasilkan keluaran sebagai berikut -

value of a before sending to function:  50 
value of b before sending to function:  70 
value of a inside the function:  70 
value of b inside the function:  50 
value of a after sending to function:  50 
value of b after sending to function:  70

Panggil dengan Nilai dengan Python

Program berikut menunjukkan bagaimana Call by Value bekerja dengan Python -

def swap(a,b): 
   t = a; 
   a = b; 
   b = t; 
   print "value of a inside the function: :",a 
   print "value of b inside the function: ",b 

# Now we can call the swap function 
a = 50 
b = 75 
print "value of a before sending to function: ",a 
print "value of b before sending to function: ",b 
swap(a,b) 
print "value of a after sending to function: ", a 
print "value of b after sending to function: ",b

Ini akan menghasilkan keluaran sebagai berikut -

value of a before sending to function:  50 
value of b before sending to function:  75 
value of a inside the function: : 75 
value of b inside the function:  50 
value of a after sending to function:  50 
value of b after sending to function:  75

Dalam Panggilan dengan Referensi, file original value is changedkarena kami menyampaikan alamat referensi argumen. Argumen aktual dan formal berbagi ruang alamat yang sama, sehingga setiap perubahan nilai di dalam fungsi tercermin di dalam maupun di luar fungsi.

Panggilan dengan Referensi di C ++

Program berikut menunjukkan bagaimana Call by Value bekerja di C ++ -

#include <iostream> 
using namespace std; 

void swap(int *a, int *b) {    
   int temp; 
   temp = *a; 
   *a = *b; 
   *b = temp; 
   cout<<"\n"<<"value of a inside the function: "<<*a; 
   cout<<"\n"<<"value of b inside the function: "<<*b; 
}  
int main() {     
   int a = 50, b = 75;   
   cout<<"\n"<<"value of a before sending to function: "<<a; 
   cout<<"\n"<<"value of b before sending to function: "<<b; 
   swap(&a, &b);  // passing value to function 
   cout<<"\n"<<"value of a after sending to function: "<<a; 
   cout<<"\n"<<"value of b after sending to function: "<<b; 
   return 0;   
}

Ini akan menghasilkan keluaran sebagai berikut -

value of a before sending to function:  50 
value of b before sending to function:  75 
value of a inside the function:  75 
value of b inside the function: 50 
value of a after sending to function:  75 
value of b after sending to function:  50

Panggil dengan Referensi dengan Python

Program berikut menunjukkan bagaimana Call by Value bekerja dengan Python -

def swap(a,b): 
   t = a; 
   a = b; 
   b = t; 
   print "value of a inside the function: :",a 
   print "value of b inside the function: ",b 
   return(a,b) 
    
# Now we can call swap function 
a = 50 
b =75 
print "value of a before sending to function: ",a 
print "value of b before sending to function: ",b 
x = swap(a,b) 
print "value of a after sending to function: ", x[0] 
print "value of b after sending to function: ",x[1]

Ini akan menghasilkan keluaran sebagai berikut -

value of a before sending to function:  50 
value of b before sending to function:  75 
value of a inside the function:  75 
value of b inside the function:  50 
value of a after sending to function:  75 
value of b after sending to function:  50

Ketika kita memiliki beberapa fungsi dengan nama yang sama tetapi parameter yang berbeda, maka fungsi tersebut dikatakan kelebihan beban. Teknik ini digunakan untuk meningkatkan keterbacaan program.

Ada dua cara untuk membebani suatu fungsi, yaitu -

  • Memiliki jumlah argumen yang berbeda
  • Memiliki tipe argumen yang berbeda

Fungsi overloading biasanya dilakukan ketika kita harus melakukan satu operasi dengan jumlah atau tipe argumen yang berbeda.

Fungsi Overloading di C ++

Contoh berikut menunjukkan bagaimana overloading fungsi dilakukan di C ++, yang merupakan bahasa pemrograman berorientasi objek -

#include <iostream> 
using namespace std;  
void addnum(int,int); 
void addnum(int,int,int); 

int main() {     
   addnum (5,5); 
   addnum (5,2,8); 
   return 0; 
} 

void addnum (int x, int y) {     
   cout<<"Integer number: "<<x+y<<endl; 
} 

void addnum (int x, int y, int z) {     
   cout<<"Float number: "<<x+y+z<<endl; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Integer number: 10 
Float number: 15

Fungsi Overloading di Erlang

Contoh berikut menunjukkan bagaimana melakukan overloading fungsi di Erlang, yang merupakan bahasa pemrograman fungsional -

-module(helloworld).  
-export([addnum/2,addnum/3,start/0]).   

addnum(X,Y) ->  
   Z = X+Y,  
   io:fwrite("~w~n",[Z]).  
    
addnum(X,Y,Z) ->  
   A = X+Y+Z,  
   io:fwrite("~w~n",[A]).  
  
start() ->
   addnum(5,5),     addnum(5,2,8).

Ini akan menghasilkan keluaran sebagai berikut -

10 
15

Ketika kelas dasar dan kelas turunan memiliki fungsi anggota dengan nama yang sama persis, tipe kembalian yang sama, dan daftar argumen yang sama, maka ini dikatakan sebagai penggantian fungsi.

Fungsi Mengganti menggunakan C ++

Contoh berikut menunjukkan bagaimana penggantian fungsi dilakukan di C ++, yang merupakan bahasa pemrograman berorientasi objek -

#include <iostream> 
using namespace std;  

class A {  
   public: 
   void display() {   
      cout<<"Base class"; 
   } 
}; 

class B:public A {  
   public: 
   void display() {   
      cout<<"Derived Class"; 
   } 
}; 

int main() {  
   B obj; 
   obj.display(); 
   return 0;  
}

Ini akan menghasilkan keluaran sebagai berikut

Derived Class

Fungsi Mengganti menggunakan Python

Contoh berikut menunjukkan cara melakukan penggantian fungsi dengan Python, yang merupakan bahasa pemrograman fungsional -

class A(object): 
   def disp(self): 
      print "Base Class"  
class B(A): 
   def disp(self): 
      print "Derived Class"  
x = A() 
y = B()  
x.disp() 
y.disp()

Ini akan menghasilkan keluaran sebagai berikut -

Base Class 
Derived Class

Suatu fungsi yang memanggil dirinya sendiri dikenal sebagai fungsi rekursif dan teknik ini dikenal sebagai rekursi. Instruksi rekursi berlanjut sampai instruksi lain mencegahnya.

Rekursi di C ++

Contoh berikut menunjukkan cara kerja rekursi di C ++, yang merupakan bahasa pemrograman berorientasi objek -

#include <stdio.h> 
long int fact(int n);  

int main() { 
   int n; 
   printf("Enter a positive integer: "); 
   scanf("%d", &n); 
   printf("Factorial of %d = %ld", n, fact(n)); 
   return 0; 
} 
long int fact(int n) { 
   if (n >= 1) 
      return n*fact(n-1); 
   else 
      return 1; 
}

Ini akan menghasilkan keluaran sebagai berikut

Enter a positive integer: 5 
Factorial of 5 = 120

Rekursi dengan Python

Contoh berikut menunjukkan bagaimana rekursi bekerja dengan Python, yang merupakan bahasa pemrograman fungsional -

def fact(n): 
   if n == 1: 
      return n 
   else: 
      return n* fact (n-1)  

# accepts input from user 
num = int(input("Enter a number: "))  
# check whether number is positive or not 

if num < 0: 
   print("Sorry, factorial does not exist for negative numbers") 
else: 
   print("The factorial of " + str(num) +  " is " + str(fact(num)))

Ini akan menghasilkan keluaran sebagai berikut -

Enter a number: 6
The factorial of 6 is 720

Fungsi orde tinggi (HOF) adalah fungsi yang mengikuti setidaknya salah satu dari kondisi berikut -

  • Mengambil atau lebih fungsi sebagai argumen
  • Mengembalikan fungsi sebagai hasilnya

HOF dalam PHP

Contoh berikut menunjukkan cara menulis fungsi orde tinggi di PHP, yang merupakan bahasa pemrograman berorientasi objek -

<?php  
$twice = function($f, $v) { return $f($f($v)); 
};  

$f = function($v) { 
   return $v + 3; }; echo($twice($f, 7));

Ini akan menghasilkan keluaran sebagai berikut -

13

HOF dengan Python

Contoh berikut menunjukkan cara menulis fungsi orde tinggi dengan Python, yang merupakan bahasa pemrograman berorientasi objek -

def twice(function): 
   return lambda x: function(function(x))  
def f(x): 
   return x + 3 
g = twice(f)
print g(7)

Ini akan menghasilkan keluaran sebagai berikut -

13

Tipe data mendefinisikan tipe nilai yang bisa dimiliki sebuah objek dan operasi apa yang bisa dilakukan padanya. Tipe data harus dideklarasikan terlebih dahulu sebelum digunakan. Bahasa pemrograman yang berbeda mendukung tipe data yang berbeda. Sebagai contoh,

  • C mendukung char, int, float, long, dll.
  • Python mendukung String, List, Tuple, dll.

Dalam arti luas, ada tiga tipe tipe data -

  • Fundamental data types- Ini adalah tipe data yang telah ditentukan yang digunakan oleh programmer secara langsung untuk menyimpan hanya satu nilai sesuai kebutuhan, yaitu tipe integer, tipe karakter, atau tipe floating. Misalnya - int, char, float, dll.

  • Derived data types- Tipe data ini diturunkan menggunakan tipe data built-in yang dirancang oleh programmer untuk menyimpan beberapa nilai dengan tipe yang sama sesuai kebutuhan mereka. Misalnya - Array, Pointer, fungsi, daftar, dll.

  • User-defined data types- Tipe data ini diturunkan menggunakan tipe data bawaan yang digabungkan menjadi satu tipe data untuk menyimpan beberapa nilai dari tipe yang sama atau tipe berbeda atau keduanya sesuai kebutuhan. Misalnya - Kelas, Struktur, dll.

Tipe Data Didukung oleh C ++

Tabel berikut mencantumkan tipe data yang didukung oleh C ++ -

Tipe data Ukuran Jarak
arang 1 byte -128 hingga 127 atau 0 hingga 255
unsigned char 1 byte 0 sampai 255
karakter bertanda tangan 1 byte -128 hingga 127
int 4 byte -2147483648 hingga 2147483647
unsigned int 4 byte 0 hingga 4294967295
ditandatangani int 4 byte -2147483648 hingga 2147483647
int pendek 2 byte -32768 hingga 32767
int pendek unsigned 2 byte 0 hingga 65.535
ditandatangani int pendek 2 byte -32768 hingga 32767
int panjang 4 byte -2.147.483.648 hingga 2.147.483.647
ditandatangani int panjang 4 byte -2.147.483.648 hingga 2.147.483.647
int panjang unsigned 4 byte 0 sampai 4.294.967.295
mengapung 4 byte +/- 3.4e +/- 38 (~ 7 digit)
dua kali lipat 8 byte +/- 1.7e +/- 308 (~ 15 digit)
ganda panjang 8 byte +/- 1.7e +/- 308 (~ 15 digit)

Jenis Data yang Didukung oleh Java

Tipe data berikut ini didukung oleh Java -

Tipe data Ukuran Jarak
byte 1 byte -128 hingga 127
arang 2 byte 0 hingga 65.536
pendek 2 byte -32,7688 hingga 32,767
int 4 byte -2.147.483.648 hingga 2.147.483.647
panjang 8 byte -9.223.372.036.854.775.808 hingga 9.223.372.036.854.775.807
mengapung 4 byte -2147483648 hingga 2147483647
dua kali lipat 8 byte + 9.223 * 1018
Boolean 1 bit Benar atau salah

Tipe Data Didukung oleh Erlang

Pada bagian ini, kita akan membahas tipe data yang didukung oleh Erlang, yang merupakan bahasa pemrograman fungsional.

Jumlah

Erlang mendukung dua jenis literal numerik, yaitu integer dan float. Lihatlah contoh berikut yang menunjukkan bagaimana menambahkan dua nilai integer -

-module(helloworld).
-export([start/0]). 
start() -> 
   io:fwrite("~w",[5+4]).

Ini akan menghasilkan keluaran berikut -

9

Atom

Sebuah atomadalah string yang nilainya tidak dapat diubah. Ini harus dimulai dengan huruf kecil dan dapat berisi karakter alfanumerik dan karakter khusus. Ketika sebuah atom berisi karakter khusus, maka atom itu harus diapit di dalam tanda kutip tunggal ('). Lihat contoh berikut untuk memahami dengan lebih baik.

-module(helloworld). 
-export([start/0]). 

start()-> 
   io:fwrite(monday).

Ini akan menghasilkan keluaran sebagai berikut -

monday

Note- Coba ubah atom menjadi "Senin" dengan huruf besar "M". Program akan menghasilkan kesalahan.

Boolean

Tipe data ini digunakan untuk menampilkan hasil sebagai baik true atau false. Lihat contoh berikut. Ini menunjukkan bagaimana membandingkan dua bilangan bulat.

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite(5 =< 9).

Ini akan menghasilkan keluaran sebagai berikut -

true

Bit String

String bit digunakan untuk menyimpan area memori yang tidak diketik. Lihat contoh berikut. Ini menunjukkan bagaimana mengubah 2 bit dari string bit menjadi daftar.

-module(helloworld). 
-export([start/0]). 

start() -> 
   Bin2 = <<15,25>>, 
   P = binary_to_list(Bin2), 
   io:fwrite("~w",[P]).

Ini akan menghasilkan keluaran sebagai berikut -

[15,25]

Tuple

Tupel adalah tipe data gabungan yang memiliki jumlah suku tetap. Setiap istilah tupel dikenal sebagaielement. Jumlah elemen adalah ukuran tupel. Contoh berikut menunjukkan bagaimana mendefinisikan tupel dari 5 istilah & mencetak ukurannya.

-module(helloworld).  
-export([start/0]).  

start() ->  
   K = {abc,50,pqr,60,{xyz,75}} ,  
   io:fwrite("~w",[tuple_size(K)]).

Ini akan menghasilkan keluaran sebagai berikut -

5

Peta

Peta adalah tipe data gabungan dengan sejumlah variabel asosiasi nilai kunci. Setiap asosiasi nilai kunci di peta disebut sebagaiassociation-pair. Itukey dan value bagian dari pasangan disebut elements. Jumlah pasangan asosiasi dikatakan sebagai ukuran peta. Contoh berikut menunjukkan bagaimana mendefinisikan peta dari 3 pemetaan dan mencetak ukurannya.

-module(helloworld).  
-export([start/0]).  
 
start() ->  
   Map1 = #{name => 'abc',age => 40, gender => 'M'},  
   io:fwrite("~w",[map_size(Map1)]).

Ini akan menghasilkan keluaran sebagai berikut -

3

Daftar

Daftar adalah tipe data majemuk yang memiliki jumlah suku yang bervariasi. Setiap istilah dalam daftar disebut elemen. Jumlah elemen dikatakan sebagai panjang daftar. Contoh berikut menunjukkan cara menentukan daftar 5 item dan mencetak ukurannya.

-module(helloworld).  
-export([start/0]).  

start() ->  
   List1 = [10,15,20,25,30] ,  
   io:fwrite("~w",[length(List1)]).

Ini akan menghasilkan keluaran sebagai berikut -

5

Note - Tipe data 'String' tidak ditentukan di Erlang.

Polimorfisme, dalam istilah pemrograman, berarti menggunakan kembali satu kode beberapa kali. Lebih khusus lagi, ini adalah kemampuan program untuk memproses objek secara berbeda tergantung pada tipe data atau kelasnya.

Polimorfisme terdiri dari dua jenis -

  • Compile-time Polymorphism - Jenis polimorfisme ini dapat dicapai dengan menggunakan metode overloading.

  • Run-time Polymorphism - Jenis polimorfisme ini dapat dicapai dengan menggunakan metode overriding dan fungsi virtual.

Keuntungan Polimorfisme

Polimorfisme menawarkan keuntungan sebagai berikut -

  • Ini membantu programmer untuk menggunakan kembali kode, yaitu, kelas yang pernah ditulis, diuji, dan diimplementasikan dapat digunakan kembali sesuai kebutuhan. Menghemat banyak waktu.

  • Variabel tunggal dapat digunakan untuk menyimpan beberapa tipe data.

  • Mudah untuk men-debug kode.

Jenis Data Polimorfik

Tipe data polimorfik dapat diimplementasikan dengan menggunakan pointer umum yang menyimpan alamat byte saja, tanpa tipe data yang disimpan pada alamat memori tersebut. Sebagai contoh,

function1(void *p, void *q)

dimana p dan q adalah petunjuk umum yang dapat digunakan int, float (atau lainnya) sebagai argumen.

Fungsi Polimorfik di C ++

Program berikut menunjukkan bagaimana menggunakan fungsi polimorfik di C ++, yang merupakan bahasa pemrograman berorientasi objek.

#include <iostream> 
Using namespace std: 

class A {  
   public: 
   void show() {    
      cout << "A class method is called/n"; 
   } 
}; 

class B:public A { 
   public: 
   void show() {   
      cout << "B class method is called/n"; 
   } 
};  

int main() {   
   A x;        // Base class object 
   B y;        // Derived class object 
   x.show();   // A class method is called 
   y.show();   // B class method is called 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

A class method is called 
B class method is called

Fungsi Polimorfik dengan Python

Program berikut menunjukkan bagaimana menggunakan fungsi polimorfik dengan Python, yang merupakan bahasa pemrograman fungsional.

class A(object): 
   def show(self): 
      print "A class method is called" 
  
class B(A): 
   def show(self): 
      print "B class method is called" 
  
def checkmethod(clasmethod): 
   clasmethod.show()  

AObj = A() 
BObj = B() 
  
checkmethod(AObj) 
checkmethod(BObj)

Ini akan menghasilkan keluaran sebagai berikut -

A class method is called 
B class method is called

SEBUAH stringadalah sekelompok karakter termasuk spasi. Kita dapat mengatakan itu adalah larik karakter satu dimensi yang diakhiri oleh karakter NULL ('\ 0'). Sebuah string juga dapat dianggap sebagai kelas yang telah ditentukan sebelumnya yang didukung oleh sebagian besar bahasa pemrograman seperti C, C ++, Java, PHP, Erlang, Haskell, Lisp, dll.

Gambar berikut menunjukkan bagaimana string "Tutorial" akan terlihat di memori.

Buat String di C ++

Program berikut adalah contoh yang menunjukkan cara membuat string dalam C ++, yang merupakan bahasa pemrograman berorientasi objek.

#include <iostream> 
using namespace std; 

int main () {    
   char greeting[20] = {'H', 'o', 'l', 'i', 'd', 'a', 'y', '\0'}; 
   cout << "Today is: "; 
   cout << greeting << endl; 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Today is: Holiday

String dalam bahasa Erlang

Program berikut adalah contoh yang menunjukkan cara membuat string di Erlang, yang merupakan bahasa pemrograman fungsional.

-module(helloworld).  
-export([start/0]).   
start() -> 
   Str = "Today is: Holiday",  
   io:fwrite("~p~n",[Str]).

Ini akan menghasilkan keluaran sebagai berikut -

"Today is: Holiday"

Operasi String di C ++

Bahasa pemrograman yang berbeda mendukung metode yang berbeda pada string. Tabel berikut menunjukkan beberapa metode string standar yang didukung oleh C ++.

S.No. Metode & Deskripsi
1

Strcpy(s1,s2)

Ini menyalin string s2 menjadi string s1

2

Strcat(s1,s2)

Ia menambahkan string s2 di akhir s1

3

Strlen(s1)

Ini memberikan panjang string s1

4

Strcmp(s1,s2)

Ini mengembalikan 0 ketika string s1 & s2 sama

5

Strchr(s1,ch)

Ini mengembalikan pointer ke kemunculan pertama karakter ch dalam string s1

6

Strstr(s1,s2)

Ini mengembalikan pointer ke kemunculan pertama string s2 dalam string s1

Program berikut menunjukkan bagaimana metode di atas dapat digunakan dalam C ++ -

#include <iostream> 
#include <cstring> 
using namespace std; 

int main () {   
   char str1[20] = "Today is "; 
   char str2[20] = "Monday"; 
   char str3[20]; 
   int  len ;  
   strcpy( str3, str1); // copy str1 into str3 
   cout << "strcpy( str3, str1) : " << str3 << endl;  

   strcat( str1, str2); // concatenates str1 and str2 
   cout << "strcat( str1, str2): " << str1 << endl;  

   len = strlen(str1);  // String length after concatenation 
   cout << "strlen(str1) : " << len << endl; 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

strcpy(str3, str1)   :  Today is 
strcat(str1, str2)   :  Today is Monday 
strlen(str1)         :  15

Operasi String di Erlang

Tabel berikut menunjukkan daftar metode string standar yang didukung oleh Erlang.

S.No. Metode & Deskripsi
1

len(s1)

Mengembalikan jumlah karakter dalam string yang diberikan.

2

equal(s1,s2)

Ini mengembalikan nilai benar ketika string s1 & s2 sama, jika tidak mengembalikan salah

3

concat(s1,s2)

Ia menambahkan string s2 di akhir string s1

4

str(s1,ch)

Ini mengembalikan posisi indeks karakter ch dalam string s1

5

str (s1,s2)

Ini mengembalikan posisi indeks s2 dalam string s1

6

substr(s1,s2,num)

Metode ini mengembalikan string s2 dari string s1 berdasarkan posisi awal & jumlah karakter dari posisi awal

7

to_lower(s1)

Metode ini mengembalikan string dalam huruf kecil

Program berikut menunjukkan bagaimana metode di atas dapat digunakan di Erlang.

-module(helloworld).  
-import(string,[concat/2]).  
-export([start/0]).  
   start() ->  
   S1 = "Today is ",  
   S2 = "Monday",  
   S3 = concat(S1,S2),  
   io:fwrite("~p~n",[S3]).

Ini akan menghasilkan keluaran sebagai berikut -

"Today is Monday"

Listadalah tipe data paling serbaguna yang tersedia dalam bahasa pemrograman fungsional yang digunakan untuk menyimpan kumpulan item data serupa. Konsepnya mirip dengan array dalam pemrograman berorientasi objek. Item daftar dapat ditulis dalam kurung siku yang dipisahkan dengan koma. Cara menulis data ke dalam daftar berbeda-beda untuk setiap bahasa.

Program Membuat Daftar Angka di Jawa

List bukanlah tipe data di Java / C / C ++, tetapi kami memiliki cara alternatif untuk membuat list di Java, yaitu dengan menggunakan ArrayList dan LinkedList.

Contoh berikut menunjukkan cara membuat daftar di Java. Di sini kami menggunakan metode Daftar Berantai untuk membuat daftar nomor.

import java.util.*; 
import java.lang.*; 
import java.io.*;  

/* Name of the class has to be "Main" only if the class is public. */ 

public class HelloWorld { 
   public static void main (String[] args) throws java.lang.Exception { 
      List<String> listStrings = new LinkedList<String>(); 
      listStrings.add("1"); 
      listStrings.add("2"); 
      listStrings.add("3"); 
      listStrings.add("4"); 
      listStrings.add("5"); 
  
      System.out.println(listStrings); 
   } 
}

Ini akan menghasilkan keluaran sebagai berikut -

[1, 2, 3, 4, 5]

Program Membuat Daftar Angka di Erlang

-module(helloworld).  
-export([start/0]).   

start() ->  
   Lst = [1,2,3,4,5],  
   io:fwrite("~w~n",[Lst]).

Ini akan menghasilkan keluaran sebagai berikut -

[1 2 3 4 5]

Daftar Operasi di Java

Pada bagian ini, kita akan membahas beberapa operasi yang dapat dilakukan melalui daftar di Java.

Menambahkan Elemen ke dalam Daftar

Metode add (Object), add (index, Object), addAll () digunakan untuk menambahkan elemen ke dalam daftar. Sebagai contoh,

ListStrings.add(3, “three”)

Menghapus Elemen dari Daftar

Metode remove (index) atau removeobject () digunakan untuk menghapus elemen dari daftar. Sebagai contoh,

ListStrings.remove(3,”three”)

Note - Untuk menghapus semua elemen dari daftar metode clear () digunakan.

Mengambil Elemen dari Daftar

Metode get () digunakan untuk mengambil elemen dari daftar di lokasi yang ditentukan. Metode getfirst () & getlast () bisa digunakan di kelas LinkedList. Sebagai contoh,

String str = ListStrings.get(2)

Memperbarui Elemen dalam Daftar

Metode set (indeks, elemen) digunakan untuk memperbarui elemen pada indeks yang ditentukan dengan elemen yang ditentukan. Sebagai contoh,

listStrings.set(2,”to”)

Menyortir Elemen dalam Daftar

Metode collection.sort () dan collection.reverse () digunakan untuk mengurutkan daftar dalam urutan naik atau turun. Sebagai contoh,

Collection.sort(listStrings)

Mencari Elemen dalam Daftar

Tiga metode berikut digunakan sesuai kebutuhan -

Boolean contains(Object) metode kembali true jika daftar berisi elemen yang ditentukan, jika tidak maka akan dikembalikan false.

int indexOf(Object) metode mengembalikan indeks kemunculan pertama dari elemen tertentu dalam daftar, jika tidak, mengembalikan -1 ketika elemen tidak ditemukan.

int lastIndexOf(Object) mengembalikan indeks kemunculan terakhir dari elemen tertentu dalam daftar, jika tidak, mengembalikan -1 ketika elemen tidak ditemukan.

Daftar Operasi di Erlang

Pada bagian ini, kita akan membahas beberapa operasi yang dapat dilakukan atas daftar di Erlang.

Menambahkan dua daftar

Metode append (listfirst, listecond) digunakan untuk membuat daftar baru dengan menambahkan dua daftar. Sebagai contoh,

append(list1,list2)

Menghapus sebuah elemen

Metode delete (elemen, listname) digunakan untuk menghapus elemen yang ditentukan dari daftar & mengembalikan daftar baru. Sebagai contoh,

delete(5,list1)

Menghapus elemen terakhir dari daftar

Metode droplast (listname) digunakan untuk menghapus elemen terakhir dari daftar dan mengembalikan daftar baru. Sebagai contoh,

droplast(list1)

Mencari sebuah elemen

Metode anggota (elemen, nama daftar) digunakan untuk mencari elemen ke dalam daftar, jika ditemukan mengembalikan nilai benar jika tidak mengembalikan salah. Sebagai contoh,

member(5,list1)

Mendapatkan nilai maksimum dan minimum

Metode max (listname) dan min (listname) digunakan untuk menemukan nilai maksimum dan minimum dalam daftar. Sebagai contoh,

max(list1)

Menyortir elemen daftar

Metode sortir (listname) dan reverse (listname) digunakan untuk mengurutkan daftar dalam urutan naik atau turun. Sebagai contoh,

sort(list1)

Menambahkan elemen daftar

Metode sum (listname) digunakan untuk menambahkan semua elemen daftar dan mengembalikan jumlahnya. Sebagai contoh,

sum(list1)

Urutkan daftar dalam urutan naik dan turun menggunakan Java

Program berikut menunjukkan cara mengurutkan daftar dalam urutan naik dan turun menggunakan Java -

import java.util.*; 
import java.lang.*; 
import java.io.*;  

public class SortList { 
   public static void main (String[] args) throws java.lang.Exception { 
      List<String> list1 = new ArrayList<String>(); 
      list1.add("5"); 
      list1.add("3"); 
      list1.add("1"); 
      list1.add("4"); 
      list1.add("2"); 
  
      System.out.println("list before sorting: " + list1); 
  
      Collections.sort(list1); 
  
      System.out.println("list in ascending order: " + list1); 
      Collections.reverse(list1); 
  
      System.out.println("list in dsending order: " + list1); 
   } 
}

Ini akan menghasilkan keluaran sebagai berikut -

list before sorting     : [5, 3, 1, 4, 2] 
list in ascending order : [1, 2, 3, 4, 5] 
list in dsending order  : [5, 4, 3, 2, 1]

Urutkan daftar dalam urutan naik menggunakan Erlang

Program berikut menunjukkan cara mengurutkan daftar dalam urutan naik dan turun menggunakan Erlang, yang merupakan bahasa pemrograman fungsional -

-module(helloworld).  
-import(lists,[sort/1]).  
-export([start/0]).   

start() ->  
   List1 = [5,3,4,2,1],  
   io:fwrite("~p~n",[sort(List1)]),

Ini akan menghasilkan keluaran sebagai berikut -

[1,2,3,4,5]

Tupel adalah tipe data gabungan yang memiliki jumlah suku tetap. Setiap istilah dalam tupel dikenal sebagaielement. Jumlah elemen adalah ukuran tupel.

Program untuk mendefinisikan tupel di C #

Program berikut menunjukkan bagaimana mendefinisikan tupel dari empat istilah dan mencetaknya menggunakan C #, yang merupakan bahasa pemrograman berorientasi objek.

using System; 
public class Test { 
   public static void Main() { 
      var t1 = Tuple.Create(1, 2, 3, new Tuple<int, int>(4, 5));   
      Console.WriteLine("Tuple:" + t1);    
   } 
}

Ini akan menghasilkan keluaran sebagai berikut -

Tuple :(1, 2, 3, (4, 5))

Program untuk mendefinisikan tupel di Erlang

Program berikut menunjukkan bagaimana mendefinisikan tupel dari empat istilah dan mencetaknya menggunakan Erlang, yang merupakan bahasa pemrograman fungsional.

-module(helloworld).  
-export([start/0]).   

start() -> 
   P = {1,2,3,{4,5}} ,  
   io:fwrite("~w",[P]).

Ini akan menghasilkan keluaran sebagai berikut -

{1, 2, 3, {4, 5}}

Keuntungan dari Tuple

Tuple menawarkan keuntungan berikut -

  • Tupel adalah ukuran fined di alam yaitu kita tidak dapat menambah / menghapus elemen ke / dari tupel.

  • Kita dapat mencari elemen apapun dalam tupel.

  • Tupel lebih cepat daripada daftar, karena mereka memiliki sekumpulan nilai yang konstan.

  • Tupel dapat digunakan sebagai kunci kamus, karena mengandung nilai yang tidak dapat diubah seperti string, angka, dll.

Tuple vs Daftar

Tuple Daftar
Tuple adalah immutable, yaitu, kami tidak dapat memperbarui datanya. Daftar adalah mutable, yaitu kita bisa mengupdate datanya.
Elemen dalam tupel bisa berbeda tipe. Semua elemen dalam daftar memiliki tipe yang sama.
Tupel dilambangkan dengan tanda kurung bulat di sekitar elemen. Daftar dilambangkan dengan tanda kurung siku di sekitar elemen.

Operasi di Tuple

Pada bagian ini, kita akan membahas beberapa operasi yang dapat dilakukan pada tupel.

Periksa apakah nilai yang dimasukkan adalah Tuple atau bukan

Metode is_tuple(tuplevalues)digunakan untuk menentukan apakah nilai yang dimasukkan adalah tupel atau bukan. Ia kembalitrue ketika nilai yang dimasukkan adalah tupel, jika tidak, nilai itu akan kembali false. Sebagai contoh,

-module(helloworld).  
-export([start/0]).  

start() ->  
   K = {abc,50,pqr,60,{xyz,75}} , io:fwrite("~w",[is_tuple(K)]).

Ini akan menghasilkan keluaran sebagai berikut -

True

Mengubah Daftar menjadi Tupel

Metode list_to_tuple(listvalues)mengubah daftar menjadi tupel. Sebagai contoh,

-module(helloworld).  
-export([start/0]).  

start() ->  
   io:fwrite("~w",[list_to_tuple([1,2,3,4,5])]).

Ini akan menghasilkan keluaran sebagai berikut -

{1, 2, 3, 4, 5}

Mengubah Tuple menjadi List

Metode tuple_to_list(tuplevalues)mengonversi tupel tertentu ke format daftar. Sebagai contoh,

-module(helloworld).  
-export([start/0]).  

start() ->  
   io:fwrite("~w",[tuple_to_list({1,2,3,4,5})]).

Ini akan menghasilkan keluaran sebagai berikut -

[1, 2, 3, 4, 5]

Periksa ukuran tupel

Metode tuple_size(tuplename)mengembalikan ukuran tupel. Sebagai contoh,

-module(helloworld).  
-export([start/0]).  

start() ->  
   K = {abc,50,pqr,60,{xyz,75}} ,  
   io:fwrite("~w",[tuple_size(K)]).

Ini akan menghasilkan keluaran sebagai berikut -

5

Record adalah struktur data untuk menyimpan sejumlah elemen. Ini mirip dengan struktur dalam bahasa C. Pada saat kompilasi, ekspresinya diterjemahkan ke dalam ekspresi tupel.

Bagaimana cara membuat rekaman?

Kata kunci 'record' digunakan untuk membuat record yang ditentukan dengan nama record dan bidangnya. Sintaksnya adalah sebagai berikut -

record(recodname, {field1, field2, . . fieldn})

Sintaks untuk memasukkan nilai ke dalam record adalah -

#recordname {fieldName1 = value1, fieldName2 = value2 .. fieldNamen = valuen}

Program untuk membuat catatan menggunakan Erlang

Dalam contoh berikut, kami telah membuat catatan nama student memiliki dua bidang, yaitu sname dan sid.

-module(helloworld).  
-export([start/0]).  
-record(student, {sname = "", sid}).   

start() ->  
   S = #student{sname = "Sachin",sid = 5}.

Program untuk membuat record menggunakan C ++

Contoh berikut menunjukkan cara membuat record menggunakan C ++, yang merupakan bahasa pemrograman berorientasi objek -

#include<iostream> 
#include<string>
using namespace std; 

class student {
   public: 
   string sname; 
   int sid; 
   15 
}; 

int main() {    
   student S;  
   S.sname = "Sachin"; 
   S.sid = 5; 
   return 0;  
}

Program untuk mengakses nilai record menggunakan Erlang

Program berikut menunjukkan bagaimana nilai record akses menggunakan Erlang, yang merupakan bahasa pemrograman fungsional -

-module(helloworld).  
-export([start/0]).  
-record(student, {sname = "", sid}).   

start() ->  
   S = #student{sname = "Sachin",sid = 5},  
   io:fwrite("~p~n",[S#student.sid]),  
   io:fwrite("~p~n",[S#student.sname]).

Ini akan menghasilkan keluaran sebagai berikut -

5 
"Sachin"

Program untuk mengakses nilai record menggunakan C ++

Program berikut menunjukkan cara mengakses nilai record menggunakan C ++ -

#include<iostream> 
#include<string> 
using namespace std; 

class student {     
   public: 
   string sname; 
   int sid; 
}; 

int main() {     
   student S;  
   S.sname = "Sachin"; 
   S.sid = 5; 
   cout<<S.sid<<"\n"<<S.sname;  
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

5 
Sachin

Nilai catatan dapat diperbarui dengan mengubah nilai ke bidang tertentu dan kemudian menetapkan catatan tersebut ke nama variabel baru. Lihatlah dua contoh berikut untuk memahami bagaimana hal itu dilakukan dengan menggunakan bahasa pemrograman berorientasi objek dan fungsional.

Program untuk memperbarui nilai record menggunakan Erlang

Program berikut menunjukkan bagaimana memperbarui nilai record menggunakan Erlang -

-module(helloworld).  
-export([start/0]).  
-record(student, {sname = "", sid}).   

start() ->  
   S = #student{sname = "Sachin",sid = 5},  
   S1 = S#student{sname = "Jonny"},  
   io:fwrite("~p~n",[S1#student.sid]),  
   io:fwrite("~p~n",[S1#student.sname]).

Ini akan menghasilkan keluaran sebagai berikut -

5
"Jonny"

Program untuk memperbarui nilai record menggunakan C ++

Program berikut menunjukkan cara memperbarui nilai record menggunakan C ++ -

#include<iostream> 
#include<string> 
using namespace std;  

class student {    
   public: 
   string sname; 
   int sid; 
};  

int main() {     
   student S;  
   S.sname = "Jonny"; 
   S.sid = 5; 
   cout<<S.sname<<"\n"<<S.sid; 
   cout<<"\n"<< "value after updating"<<"\n"; 
   S.sid = 10; 
   cout<<S.sname<<"\n"<<S.sid; 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Jonny 
5 
value after updating 
Jonny 
10

Kalkulus Lambda adalah kerangka kerja yang dikembangkan oleh Gereja Alonzo pada tahun 1930-an untuk mempelajari komputasi dengan fungsi.

  • Function creation - Gereja memperkenalkan notasinya λx.Euntuk menunjukkan fungsi di mana 'x' adalah argumen formal dan 'E' adalah badan fungsional. Fungsi ini bisa tanpa nama dan argumen tunggal.

  • Function application - Gereja menggunakan notasi itu E1.E2 untuk menunjukkan penerapan fungsi E1 untuk argumen sebenarnya E2. Dan semua fungsi dalam satu argumen.

Sintaks Kalkulus Lambda

Kalkulus Lamdba mencakup tiga jenis ekspresi, yaitu,

E :: = x (variabel)

| E 1 E 2 (aplikasi fungsi)

| λx.E (pembuatan fungsi)

Dimana λx.E disebut abstraksi Lambda dan E dikenal sebagai λ-ekspresi.

Mengevaluasi Kalkulus Lambda

Kalkulus lambda murni tidak memiliki fungsi bawaan. Mari kita evaluasi ekspresi berikut -

(+ (* 5 6) (* 8 3))

Di sini, kita tidak dapat memulai dengan '+' karena hanya beroperasi pada angka. Ada dua ekspresi yang dapat direduksi: (* 5 6) dan (* 8 3).

Kita bisa mengurangi salah satunya dulu. Misalnya -

(+ (* 5 6) (* 8 3)) 
(+ 30 (* 8 3)) 
(+ 30 24) 
= 54

Aturan pengurangan β

Kami membutuhkan aturan pengurangan untuk menangani λs

(λx . * 2 x) 4 
(* 2 4) 
= 8

Ini disebut reduksi β.

Parameter formal dapat digunakan beberapa kali -

(λx . + x x) 4 
(+ 4 4) 
= 8

Jika ada beberapa istilah, kami dapat menanganinya sebagai berikut -

(λx . (λx . + (− x 1)) x 3) 9

Batin x milik batin λ dan x luar milik yang terluar.

(λx . + (− x 1)) 9 3 
+ (− 9 1) 3 
+ 8 3 
= 11

Variabel Bebas dan Terikat

Dalam ekspresi, setiap kemunculan variabel bisa "bebas" (ke λ) atau "terikat" (ke λ).

reduksi β dari (λx . E) y menggantikan setiap x yang terjadi gratis di E dengan y. Sebagai Contoh -

Pengurangan Alfa

Reduksi alfa sangat sederhana dan dapat dilakukan tanpa mengubah arti ekspresi lambda.

λx . (λx . x) (+ 1 x) ↔ α λx . (λy . y) (+ 1 x)

Misalnya -

(λx . (λx . + (− x 1)) x 3) 9 
(λx . (λy . + (− y 1)) x 3) 9 
(λy . + (− y 1)) 9 3 
+ (− 9 1) 3 
+ 8 3 
11

Teorema Church-Rosser

Teorema Church-Rosser menyatakan sebagai berikut -

  • Jika E1 ↔ E2, maka ada E sehingga E1 → E dan E2 → E. “Reduksi dengan cara apapun pada akhirnya dapat menghasilkan hasil yang sama.”

  • Jika E1 → E2, dan E2 adalah bentuk normal, maka terjadi reduksi orde normal dari E1 menjadi E2. “Reduksi orde normal akan selalu menghasilkan bentuk normal, jika ada.”

Evaluasi malas adalah strategi evaluasi yang mengadakan evaluasi suatu ekspresi hingga nilainya dibutuhkan. Ini menghindari evaluasi berulang.Haskell adalah contoh yang baik dari bahasa pemrograman fungsional yang fundamentalnya didasarkan pada Evaluasi Malas.

Evaluasi malas digunakan dalam fungsi peta Unix untuk meningkatkan kinerjanya dengan hanya memuat halaman yang diperlukan dari disk. Tidak ada memori yang akan dialokasikan untuk halaman yang tersisa.

Evaluasi Malas - Keuntungan

  • Ini memungkinkan runtime bahasa untuk membuang sub-ekspresi yang tidak langsung ditautkan ke hasil akhir ekspresi.

  • Ini mengurangi kompleksitas waktu dari suatu algoritma dengan membuang penghitungan dan persyaratan sementara.

  • Hal ini memungkinkan programmer untuk mengakses komponen struktur data yang rusak setelah menginisialisasi mereka, selama mereka bebas dari dependensi melingkar.

  • Ini paling cocok untuk memuat data yang akan jarang diakses.

Evaluasi Malas - Kekurangan

  • Ini memaksa runtime bahasa untuk menahan evaluasi sub-ekspresi hingga diperlukan dalam hasil akhir dengan membuat thunks (benda tertunda).

  • Terkadang itu meningkatkan kompleksitas ruang dari suatu algoritma.

  • Sangat sulit untuk menemukan kinerjanya karena mengandung banyak ekspresi sebelum dieksekusi.

Evaluasi Malas menggunakan Python

Itu rangemetode dengan Python mengikuti konsep Evaluasi Malas. Ini menghemat waktu eksekusi untuk rentang yang lebih besar dan kami tidak pernah memerlukan semua nilai pada satu waktu, jadi ini juga menghemat konsumsi memori. Lihat contoh berikut.

r = range(10) 
print(r) 
range(0, 10) 
print(r[3])

Ini akan menghasilkan keluaran sebagai berikut -

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
3

Kita membutuhkan file untuk menyimpan output suatu program saat program berakhir. Dengan menggunakan file, kita dapat mengakses informasi terkait menggunakan berbagai perintah dalam berbagai bahasa.

Berikut adalah daftar beberapa operasi yang dapat dilakukan pada file -

  • Membuat file baru
  • Membuka file yang sudah ada
  • Membaca konten file
  • Mencari data pada sebuah file
  • Menulis ke dalam file baru
  • Memperbarui konten ke file yang sudah ada
  • Menghapus file
  • Menutup file

Menulis ke dalam File

Untuk menulis konten ke dalam file, pertama-tama kita harus membuka file yang diperlukan. Jika file yang ditentukan tidak ada, maka file baru akan dibuat.

Mari kita lihat cara menulis konten ke dalam file menggunakan C ++.

Contoh

#include <iostream> 
#include <fstream> 
using namespace std;  

int main () {   
   ofstream myfile; 
   myfile.open ("Tempfile.txt", ios::out); 
   myfile << "Writing Contents to file.\n"; 
   cout << "Data inserted into file"; 
   myfile.close(); 
   return 0; 
}

Note -

  • fstream adalah kelas aliran yang digunakan untuk mengontrol operasi baca / tulis file.

  • ofstream adalah kelas aliran yang digunakan untuk menulis konten ke dalam file.

Mari kita lihat bagaimana menulis konten ke dalam file menggunakan Erlang, yang merupakan bahasa pemrograman fungsional.

-module(helloworld).  
-export([start/0]).   

start() ->
   {ok, File1} = file:open("Tempfile.txt", [write]),  
   file:write(File1,"Writting contents to file"), 
   io:fwrite("Data inserted into file\n").

Note -

  • Untuk membuka file kita harus menggunakan, open(filename,mode).

  • Sintaks untuk menulis konten ke file: write(filemode,file_content).

Output - Ketika kita menjalankan kode ini "Menulis konten ke file" akan ditulis ke dalam file Tempfile.txt. Jika file memiliki konten yang sudah ada, maka file tersebut akan ditimpa.

Membaca dari File

Untuk membaca dari sebuah file, pertama-tama kita harus membuka file yang ditentukan di reading mode. Jika file tidak ada, maka metode masing-masing mengembalikan NULL.

Program berikut menunjukkan cara membaca konten file di C++ -

#include <iostream> 
#include <fstream> 
#include <string> 
using namespace std;  

int main () {
   string readfile; 
   ifstream myfile ("Tempfile.txt",ios::in); 
   
   if (myfile.is_open()) {     
      while ( getline (myfile,readfile) ) {       
         cout << readfile << '\n'; 
      } 
      myfile.close(); 
   } else  
      cout << "file doesn't exist";  
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

Writing contents to file

Note- Dalam program ini, kami membuka file teks dalam mode baca menggunakan “ios :: in” dan kemudian mencetak isinya di layar. Kami telah menggunakanwhile loop untuk membaca isi file baris demi baris dengan menggunakan metode "getline".

Program berikut menunjukkan bagaimana melakukan operasi yang sama dengan menggunakan Erlang. Di sini, kami akan menggunakanread_file(filename) metode untuk membaca semua konten dari file yang ditentukan.

-module(helloworld).  
-export([start/0]).   

start() ->  
   rdfile = file:read_file("Tempfile.txt"),  
   io:fwrite("~p~n",[rdfile]).

Ini akan menghasilkan keluaran sebagai berikut -

ok, Writing contents to file

Hapus File yang Ada

Kami dapat menghapus file yang ada menggunakan operasi file. Program berikut ini menunjukkan cara menghapus file yang sudah adausing C++ -

#include <stdio.h> 

int main () {   
   if(remove( "Tempfile.txt" ) != 0 ) 
      perror( "File doesn’t exist, can’t delete" ); 
   else 
      puts( "file deleted successfully " ); 
   return 0; 
}

Ini akan menghasilkan keluaran sebagai berikut -

file deleted successfully

Program berikut menunjukkan bagaimana Anda dapat melakukan operasi yang sama dalam Erlang. Di sini, kami akan menggunakan metode tersebutdelete(filename) untuk menghapus file yang sudah ada.

-module(helloworld).  
-export([start/0]).   

start() ->  
   file:delete("Tempfile.txt").

Output - Jika file “Tempfile.txt” ada, maka akan dihapus.

Menentukan Ukuran File

Program berikut menunjukkan bagaimana Anda dapat menentukan ukuran file menggunakan C ++. Di sini, fungsinyafseek mengatur indikator posisi yang terkait dengan aliran ke posisi baru, sedangkan ftell mengembalikan posisi saat ini di arus.

#include <stdio.h> 

int main () {  
   FILE * checkfile; 
   long size; 
   checkfile = fopen ("Tempfile.txt","rb"); 
   
   if (checkfile == NULL)  
      perror ("file can’t open"); 
   else {   
      fseek (checkfile, 0, SEEK_END);    // non-portable 
      size = ftell (checkfile); 
      fclose (checkfile); 
      printf ("Size of Tempfile.txt: %ld bytes.\n",size); 
   } 
   return 0; 
}

Output - Jika file “Tempfile.txt” ada, maka ukurannya akan ditampilkan dalam byte.

Program berikut menunjukkan bagaimana Anda dapat melakukan operasi yang sama di Erlang. Di sini, kami akan menggunakan metode tersebutfile_size(filename) untuk menentukan ukuran file.

-module(helloworld).  
-export([start/0]).   

start() ->  
   io:fwrite("~w~n",[filelib:file_size("Tempfile.txt")]).

Output- Jika file “Tempfile.txt” ada, maka ukurannya akan ditampilkan dalam byte. Jika tidak, ini akan menampilkan "0".