Haskell

bahasa pemrograman fungsional

Haskell adalah bahasa pemrograman fungsional murni. Nama bahasa pemrograman Haskell diambil dari nama seseorang matematikawan Haskell Curry, yang terkenal akan karyanya di bidang combinatory logic. Haskell hanya mengenal expression dan equation.

Haskell
Logo of Haskell
ParadigmaFungsional, malas/tidak ketat, modular
Dirancang olehLennart Augustsson, Dave Barton, Brian Boutel, Warren Burton, Joseph Fasel, Kevin Hammond, Ralf Hinze, Paul Hudak, John Hughes, Thomas Johnsson, Mark Jones, Simon Peyton Jones, John Launchbury, Erik Meijer, John Peterson, Alastair Reid, Colin Runciman, Philip Wadler
Rilis perdana1990
Rilis stabil
Marlow, Simon (24 November 2009). "Announcing Haskell 2010". Haskell mailing list. http://www.haskell.org/pipermail/haskell/2009-November/021750.html. Diakses pada 12 March 2011. </ref> / Juli 2010; 14 tahun lalu (2010-07)
Rilis pratayang
Haskell 2011[butuh rujukan]
Tipe sistemStatis, kuat, disimpulkan
Sistem operasiLintas platform
Ekstensi nama berkas.hs, .lhs
Situs webhaskell.org
Repositoriwww.haskell.org
Implementasi utama
Dialek
Helium, Gofer, Hugs, Ωmega
Terpengaruh oleh
APL,[butuh rujukan] Clean,[1] FP,[1] Gofer,[1] Hope dan Hope+,[1] Id,[1] ISWIM,[1] KRC,[1] Lisp,[1] Miranda,[1] ML and Standard ML,[1] Orwell, SASL,[1] SISAL,[1] Scheme[1]
Mempengaruhi
Agda,[2] Bluespec,[butuh rujukan] C++11/Concepts,[3] C#/LINQ,[4][5] CAL,[butuh rujukan] Cayenne,[butuh rujukan] Clean,[6] Clojure,[7] CoffeeScript,[8] Curry,[butuh rujukan] Epigram,[butuh rujukan] Escher,[butuh rujukan] F#,[9] Factor,[butuh rujukan] Isabelle,[butuh rujukan] Java Generics,[butuh rujukan] Kaya,[butuh rujukan] Mercury,[butuh rujukan] Omega,[butuh rujukan] Perl 6,[10] Python,[11] Qi,[butuh rujukan] Scala,[12] Timber,[butuh rujukan] Visual Basic 9.0[13]
Sunting kotak info
Sunting kotak info • L • B
Info templat
Bantuan penggunaan templat ini

Semantik Haskell secara historis didasarkan pada bahasa pemrograman Miranda, yang berfungsi untuk memfokuskan upaya kelompok kerja Haskell awal.[14] Spesifikasi formal terakhir dari bahasa tersebut dibuat pada bulan Juli 2010, sementara pengembangan GHC terus memperluas Haskell melalui ekstensi bahasa.

Haskell digunakan dalam akademi dan industri.[15][16][17] Hingga Mei 2021, Haskell adalah bahasa pemrograman terpopuler ke-28 menurut Google Pencarian untuk tutorial,[18] dan berjumlah kurang dari 1% pengguna aktif di repositori kode sumber GitHub.[19]

Sejarah

sunting

Setelah perilisan Miranda oleh Research Software Ltd. pada tahun 1985, minat terhadap bahasa fungsional yang malas tumbuh. Pada tahun 1987, ada lebih dari selusin bahasa pemrograman yang tidak ketat dan murni fungsional. Miranda merupakan yang paling banyak digunakan, tapi itu adalah perangkat lunak berpemilik. Pada konferensi Functional Programming Languages and Computer Architecture (FPCA '87) di Portland, Oregon, ada konsensus yang kuat bahwa sebuah komite dibentuk untuk menentukan standar terbuka untuk bahasa-bahasa tersebut. Tujuan komite ini adalah untuk menggabungkan bahasa-bahasa fungsional yang ada menjadi bahasa yang umum untuk digunakan sebagai dasar pengmebangan masa depan dalam desain bahasa fungsional.[20]

Standar mendatang

sunting

Spesifikasi formal berikutnya telah direncanakan untuk tahun 2020.[21] Pada 29 Oktober 2021, dengan versi GHC 9.2.1, ekstensi GHC2021 dirilis. Meskipun ini bukan spesifikasi bahasa formal, ini menggabungkan sejumlah ekstensi GHC yang stabil dan banyak digunakan pada Haskell 2010.[22][23]

Haskell menyediakan evaluasi malas, ekspresi lambda, pencocokan pola, pemahaman daftar, tipe kelas, dan polimorfisme tipe. Ini adalah bahasa pemrograman yang murni fungsional, yang berarti bahwa fungsi pada umumnya tidak mempunyai efek samping. Ada konstruksi berbeda untuk mewakili efek samping, ortogonal terhadap jenis fungsinya. Sebuah fungsi murni dapat mengembalikan sebuah efek samping yang kemudian dieksekusi, memodelkan fungsi tidak murni dari bahasa lain.

Haskell memiliki sistem tipe statis yang kuat berdasarkan inferensi jenis Hindley – Milner. Inovasi utamanya dalam bidang ini adalah kelas tipe, yang awalnya dipahami sebagai cara berprinsip untuk menambah beban berlebih pada bahasa,[24] tetapi telah menemukan banyak pengguna baru.[25]

Terdapat komunitas yang aktif dan berkembang seputar bahasa ini, dan lebih dari 5.400 perpustakaan dan alat sumber terbuka pihak ketiga tersedia di repositori paket daring Hackage.[26]

Contoh

sunting

Hello World

sunting

Berikut ini adalah contoh program sederhana yang akan mencetak kalimat "Hello, World!".

    main = putStrLn "Hello, world!"

Penjumlahan sederhana

sunting

Berikut ini adalah contoh program sederhana yang akan mencetak hasil penjumlahan antara 2 dan 10.

    main = print (2 + 10)

Cetak nama

sunting

Berikut ini adalah contoh program sederhana yang akan meminta nama pengguna dan mencetaknya kembali.

    main = do
        putStrLn "Masukan nama Anda:"
        nama <- getLine
        putStrLn ("Selamat datang, " ++ nama ++ "!")

Penggunaan terkenal

sunting
  • Asisten pembuktian Agda ditulis dalam Haskell.[27]
  • Cabal adalah sebuah alat untuk membuat dan mengemas program dan pustaka Haskell.[28]
  • Darcs adalah sistem kontrol revisi yang ditulis dalam Haskell, dengan beberapa fitur inovatif, seperti kontrol patch yang akan diterapkan lebih tepat.
  • Glasgow Haskell Compiler (GHC) juga sering kali menjadi tempat uji coba untuk fitur pemrograman fungsional tingkat lanjut dan pengoptimalan dalam bahasa pemrograman lain.
  • Git-annex adalah sebuah alat untuk mengatur berkas data (besar) di bawah kontrol versi Git. It also provides a distributed file synchronization system (git-annex assistant).
  • Linspire Linux memilih Haskell untuk pengembangan alat sistem.[29]
  • Pandoc adalah alat untuk mengubah satu format markup ke format markup lainnya.
  • Pugs adalah kompilator dan penerjemah untuk bahasa pemrograman yang kemudian diberi nama Perl 6, namun sejak berganti nama Raku.

Kerangka web terkenal yang ditulis untuk Haskell termasuk:[30]

Referensi

sunting
  1. ^ a b c d e f g h i j k l m Haskell 98 Report, p. xi
  2. ^ Norell, Ulf (2008). "Dependently Typed Programming in Agda" (PDF). Gothenburg: Chalmers University. Diarsipkan (PDF) dari versi asli tanggal 2014-04-01. Diakses tanggal 9 February 2012. 
  3. ^ Stroustrup, Bjarne; Sutton, Andrew (2011). "Design of Concept Libraries for C++" (PDF). Diarsipkan dari versi asli (PDF) tanggal 2011-08-25. Diakses tanggal 2021-02-21. 
  4. ^ Meijer, Erik (1 October 2009). "C9 Lectures: Dr. Erik Meijer - Functional Programming Fundamentals, Chapter 1 of 13". Channel 9. Microsoft. Diarsipkan dari versi asli tanggal 2012-06-16. Diakses tanggal 9 February 2012. 
  5. ^ Drobi, Sadek (4 March 2009). "Erik Meijer on LINQ". InfoQ. QCon SF 2008: C4Media Inc. Diarsipkan dari versi asli tanggal 2021-01-26. Diakses tanggal 9 February 2012. 
  6. ^ Hudak, Paul; Hughes, John; Peyton Jones, Simon; Wadler, Philip (2007). "A history of Haskell: being lazy with class". Proceedings of the third ACM SIGPLAN conference on History of programming languages (HOPL III): 12–1–12–55. doi:10.1145/1238844.1238856. ISBN [[Special:BookSources/978-1-59593-766-X |978-1-59593-766-X [[Kategori:Artikel dengan ISBN salah]]]] Periksa nilai: invalid character |isbn= (bantuan). 
  7. ^ Hickey, Rich. "Clojure Bookshelf". Listmania!. Amazon.com. Diarsipkan dari versi asli tanggal 2012-03-19. Diakses tanggal 9 February 2012. 
  8. ^ Heller, Martin (18 October 2011). "Turn up your nose at Dart and smell the CoffeeScript". JavaWorld. InfoWorld. Diarsipkan dari versi asli tanggal 2012-02-10. Diakses tanggal 9 February 2012. 
  9. ^ Syme, Don; Granicz, Adam; Cisternino, Antonio (2007). Expert F#. Apress. hlm. 2. F# also draws from Haskell particularly with regard to two advanced language features called sequence expressions and workflows. 
  10. ^ "Glossary of Terms and Jargon". Perl Foundation Perl 6 Wiki. The Perl Foundation. 28 February. Diarsipkan dari versi asli tanggal 2012-01-21. Diakses tanggal 9 February 2012. 
  11. ^ Kuchling, A. M. "Functional Programming HOWTO". Python v2.7.2 documentation. Python Software Foundation. Diarsipkan dari versi asli tanggal 2012-10-24. Diakses tanggal 9 February 2012. 
  12. ^ Fogus, Michael (6 August 2010). "MartinOdersky take(5) toList". Send More Paramedics. Diarsipkan dari versi asli tanggal 2012-02-14. Diakses tanggal 9 February 2012. 
  13. ^ Erik Meijer, "Confessions of a Used Programming Language Salesman",[1] OOPSLA 2007
  14. ^ Edward Kmett, Edward Kmett – Type Classes vs. the World
  15. ^ Mossberg, Erik (2020-06-08), erkmos/haskell-companies, diakses tanggal 2020-06-22 
  16. ^ O'Sullivan, Bryan; Goerzen, John; Stewart, Donald Bruce (15 November 2008). Real World Haskell: Code You Can Believe In (dalam bahasa Inggris). "O'Reilly Media, Inc.". hlm. xxviii–xxxi. ISBN 978-0-596-55430-9. 
  17. ^ "Haskell in Production: Riskbook". Serokell Software Development Company (dalam bahasa Inggris). Diakses tanggal 2021-09-07. 
  18. ^ "PYPL PopularitY of Programming Language index". pypl.github.io (dalam bahasa Inggris). May 2021. Diarsipkan dari versi asli tanggal 7 May 2021. Diakses tanggal 16 May 2021. 
  19. ^ Frederickson, Ben. "Ranking Programming Languages by GitHub Users". www.benfrederickson.com. Diakses tanggal 6 September 2019. 
  20. ^ Peyton Jones 2003, Preface.
  21. ^ Kesalahan pengutipan: Tag <ref> tidak sah; tidak ditemukan teks untuk ref bernama 2020committee
  22. ^ GHC 2020 Team (29 October 2021) GHC 9.2.1 released
  23. ^ Proposed compiler and language changes for GHC and GHC/Haskell
  24. ^ Wadler, P.; Blott, S. (1989). "How to make ad-hoc polymorphism less ad hoc". Proceedings of the 16th ACM SIGPLAN-SIGACT symposium on Principles of programming languages - POPL '89. ACM. hlm. 60–76. doi:10.1145/75277.75283 . ISBN 978-0-89791-294-5. 
  25. ^ Hallgren, T. (January 2001). "Fun with Functional Dependencies, or Types as Values in Static Computations in Haskell". Proceedings of the Joint CS/CE Winter Meeting. Varberg, Sweden. 
  26. ^ "HackageDB statistics". Hackage.haskell.org. Diarsipkan dari versi asli tanggal 3 May 2013. Diakses tanggal 26 June 2013. 
  27. ^ Agda 2, Agda Github Community, 2021-10-15, diakses tanggal 2021-10-16 
  28. ^ "The Haskell Cabal". Diakses tanggal 8 April 2015. 
  29. ^ "Linspire/Freespire Core OS Team and Haskell". Debian Haskell mailing list. May 2006. Diarsipkan dari versi asli tanggal 27 December 2017. Diakses tanggal 14 June 2006. 
  30. ^ "Web/Frameworks – HaskellWiki". wiki.haskell.org. Diakses tanggal 17 September 2022. 

Pranala luar

sunting
Various
Tutorials