Koodin järjestäminen funktioihin

Haskell:
Koodin järjestäminen funktioihin

Miten:

Tässä on, miten voit kirjoittaa ja käyttää funktioita Haskellissa:

-- Määritellään yksinkertainen funktio kahden numeron yhteenlaskuun
addNumbers :: Int -> Int -> Int
addNumbers x y = x + y

-- Funktion käyttö
main = print (addNumbers 3 5)

Tuloste:

8

Voit myös luoda korkeamman asteen funktioita:

-- Ottaa funktion ja soveltaa sitä kahdesti johonkin
applyTwice :: (a -> a) -> a -> a
applyTwice f x = f (f x)

-- Käyttää applyTwice-funktiota anonyymin funktion kanssa
main = print (applyTwice (*2) 5)

Tuloste:

20

Syventävä osio

Haskell, joka on puhtaasti funktionaalinen kieli, kohtelee funktioita ensiluokkaisen kansalaisen asemassa. Historiallisesti tämä juontaa juurensa lambda-kalkyylista, joka on laskennan perustava teoreettinen viitekehys. Toisin kuin imperatiivisissa kielissä, joissa funktiot ovat sarja ohjeita, Haskellissa funktiot ovat ilmaisuja, jotka kuvaavat suhteita tietojen välillä.

On vaihtoehtoja alastomien funktioiden kirjoittamiselle uudelleenkäyttöön. Harkitse tyyppiluokkien käyttöä polymorfismia varten tai moduulien hyödyntämistä liittyvien funktioiden ryhmittelyyn. Haskellin laiska evaluointi vaikuttaa myös funktion toteutukseen – funktiot eivät evaluoidu ennen kuin niiden tuloksia tarvitaan, mikä voi vaikuttaa suorituskykyyn liittyviin seikkoihin.

Katso myös