Pemrograman Fungsional - Evaluasi Malas

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