Lisp | |
---|---|
Semantiikka | moniparadigma : olio- , toiminnallinen , proseduuriohjelmointi |
Kieliluokka | moniparadigmaohjelmointikieli , toiminnallinen ohjelmointikieli , prosessiohjelmointikieli , heijastava ohjelmointikieli [d] , metaohjelmointikieli [d] ja tulkittu ohjelmointikieli |
Esiintyi | 1958 |
Tekijä | John McCarthy |
Kehittäjä | John McCarthy [1] ja Steve Russell [d] |
Tyyppijärjestelmä | vahva , dynaaminen |
Murteet |
Common Lisp ( CLOS ), Scheme , Arc , Clojure - laajennuskielet: AutoLisp ja ELisp |
Vaikutettu | Tietojenkäsittelykieli [d] |
vaikutti | Io , Nemerle , Python , Ruby , Smalltalk , Logo , Factor , Perl , Nim |
Mediatiedostot Wikimedia Commonsissa |
Lisp ( LISP , englannin kielestä LISt Processing Language - "List Processing Language"; nykyaikainen oikeinkirjoitus: Lisp ) on ohjelmointikielien , ohjelmien ja tietojen perhe , joka esitetään lineaarisilla merkkiluetteloilla . John McCarthy loi Lispin tekoälyä varten, ja se on edelleen yksi tärkeimmistä työkaluista tällä alalla. Sitä käytetään myös tavanomaisen teollisen ohjelmoinnin välineenä sulautetuista skripteistä massakäyttöisiin verkkosovelluksiin, vaikka sitä ei voida kutsua suosituksi.
Se on yksi vanhimmista ( Fortranin ja Cobolin ohella) nykyään käytössä olevista korkean tason ohjelmointikielistä [2] ja ensimmäinen edelleen käytössä oleva automaattinen muistinhallinta ja roskienkeräys [3] .
Perinteisessä Lispissä on dynaaminen tyyppijärjestelmä . Kieli on toiminnallinen , mutta varhaisista versioista lähtien siinä on myös imperatiivisuuden piirteitä , lisäksi täysimittaisten symbolisten prosessointimahdollisuuksien ansiosta se mahdollistaa oliosuuntauksen toteuttamisen ; esimerkki tällaisesta toteutuksesta on CLOS - alusta .
Se on järjestelmäohjelmointikieli niin sanotuille Lisp-koneille , jotka on tuotettu 1980-luvulla , esimerkiksi Symbolics .
Ada- kielen ohella Lisp kävi läpi perustavanlaatuisen standardointiprosessin teollista käyttöä varten, mikä johti Common Lisp -murteeseen , jonka ANSI myöhemmin standardoi . Sen toteutukset ovat olemassa useimmille alustoille.
Lisp on kirjainkokoa huomioimaton kieli. Kielen aakkoset rajoittuivat alun perin ASCII -merkkitaulukkoon , jotkut nykyaikaiset toteutukset tukevat Unicodea .
Kielen peruselementtejä ovat symbolit, atomit ja niistä rakennetut dynaamiset listarakenteet - S-lausekkeet .
Lisp- symboli on koneen muistissa oleva objekti, joka on kokoelma "paikkoja" - soluja, jotka tallentavat viittauksia. Joillakin paikoilla on alun perin kielen määrittelemä tarkoitus:
Aikojen joukko on dynaamisesti laajennettavissa ja siksi sitä voidaan käyttää mielivaltaisten symboliominaisuuksien luettelona (voit vapaasti laajentaa paikkajärjestelmää ongelman ratkaisemiseen sopivalla tavalla). Tämä esitys mahdollistaa symbolien katsomisen monikoordinaattisen verkon solmuiksi, joissa jokainen koordinaatti on kirjoitettu omaan paikkaansa.
Atomit ovat symboleja ja numeroita. Numerot eivät ole Lisp-symboleita, koska niillä voi olla vain oma numeerinen arvo, ei muuta. Samalla numerot ja symbolit voidaan sisällyttää luetteloihin. Tämä on syy yhdistää nämä kaksi käsitettä yhdeksi yleiseksi kategoriaksi.
Lispin perustietorakenne on dynaaminen atomiluettelo , joka määritellään rekursiivisesti pääobjektiksi ja siihen liitetyksi häntälistaksi. Koska listan pää voi olla myös lista, lista on mielivaltaisen puun esitysmuoto (ylitason lista itsessään on juuri, sen toisen ja sitä seuraavien tason alilistat ovat solmuja, atomit ovat lehtiä). Atomille ja listoille kieli käyttää äärimmäisen primitiivistä hakasulkeiden syntaksia: symboli esitetään sen nimellä, numero esitetään sen arvolla ja luettelo esitetään suluissa olevien luetteloiden ja atomien sarjana, jossa peräkkäiset atomit on erotettu toisistaan. välilyönnillä tarvittaessa.
Lista on sarja kaikenlaisia elementtejä, mukaan lukien muut luettelot. Se (1 3/7 'foo #'+)koostuu esimerkiksi kokonaisluvusta, rationaalisesta murtoluvusta, symbolista foo ja osoittimesta summausfunktioon . Lausekkeet esitetään etuliitteillä varustetuilla listoilla : ensimmäisen elementin on oltava muoto , eli funktio , operaattori , makro tai erikoisoperaattori ; muut elementit ovat tämän lomakkeen argumentteja , jotka välitetään lomakkeelle käsittelyä varten. Aritmeettiset operaattorit kirjoitetaan samalla periaatteella, esimerkiksi se antaa 10 (infix-merkinnällä tämä on ). (+ 4 (* 2 3))2 * 3 + 4
Syntaksi Backus - Naur-muodossa :
s_lauseke ::= atomi_symboli | "(" s_expression "." s_expression ")" | lista lista ::= "(" s_expression { s_expression } ")" atomi_symboli ::= kirjain atomin_osa atom_part ::= tyhjä | kirjain atom_part | numero atom_part kirjain ::= "a" | "b" | "..." | "z" numero ::= "1" | "2" | "..." | "9" tyhjä ::= " "Lisp-ohjelman ominainen piirre on, että tässä primitiivisessä syntaksissa on kuvattu ehdottomasti kaikki: sekä data että koodi minkä tahansa monimutkaisuuden vuoksi. Tällä lähestymistavalla on kaksi tulosta:
Mikä tahansa Lisp-ohjelma koostuu lausekkeiden (lomakkeiden) sekvenssistä. Ohjelman tulos on näiden lausekkeiden arviointi. Kaikki lausekkeet kirjoitetaan listoina, yksi Lispin päärakenteista, joten ne voidaan helposti luoda itse kielen sisällä. Tämän avulla voit luoda ohjelmia, jotka muokkaavat muita ohjelmia tai makroja , jolloin voit laajentaa merkittävästi kielen ominaisuuksia.
Lispin edistyneet toteutukset sisältävät satoja järjestelmätoimintoja, makroja ja operaattoreita. Vain ne niistä on annettu tässä, jotka muodostavat perustan työskentelylle luetteloiden kanssa ja toiminnallisten ohjelmien luomiselle Lispissä.
T ja NIL Lispin sisäänrakennetut vakiosymbolit, jotka osoittavat loogista tosi ja epätosi. Arvot Tja NILpalauttavat loogiset operaattorit ja vertailuoperaattorit ja funktiot. Lisäksi symbolilla NILon vielä yksi merkitys - se voi tarkoittaa tyhjää luetteloa. CAR ja CDR Funktiot palauttavat luettelon pään ja hännän, vastaavasti: (CAR '(A B C D)) ==>> A(jäljempänä esimerkeissä ==>>tarkoittaa sitä, että vasemman puolen arvioinnin tuloksena Lisp-tulkki tuottaa sen, mikä on oikealla) (CAR '((A B)(C D))) ==>> (A B) (CDR '(A B C D)) ==>> (B C D) (CDR '((A B)(C D))) ==>> ((C D)) Huomaa, että jälkimmäisessä tapauksessa palautetaan listan sisällä oleva lista: argumentin loppu on yksialkioinen lista, joka itse on kahden elementin luettelo. Muodollisesti puhtaassa toiminnallisessa ohjelmoinnissa tyhjän listan pään merkitys on määrittelemätön, mutta Lispillä (ainakin useimmissa murteissa) on käytäntö, että sekä tyhjän listan pää että häntä ovat yhtä suuret NIL. (CAR NIL) ==>> NIL (CDR NIL) ==>> NIL Järjestelmätoiminnot CARsaivat CDRniin epätavalliset nimet historiallisista syistä. IBM 704 -kone , jolla McCarthy loi aivan ensimmäisen Lisp-toteutuksen, sisälsi ohjeet konesanan osien muokkaamiseen. Konesanaa pidettiin rakenteena, jossa oli etuliite-, dekrementti-, tagi- ja osoitekentät. Funktiot CAR(lyhenne sanoista Rekisterin osoiteosan sisältö ) ja ( Rekisterin alennusosan sisältö ) saivat nimensä näiden kenttien mukaisesti [5] . Tässä toteutuksessa osoite- ja vähennyskenttiä käytettiin tallentamaan osoittimia luettelon päähän ja loppuun. Joissakin uusissa Lisp-toteutuksissa perinteiset nimet on korvattu ja (eng. "first" ja "remainder", vastaavasti) tai täydennetty näillä synonyymeillä.CDRFIRSTREST C*R Tässä funktion nimessä olevan tähden "*" sijasta voi olla 2-4 kirjainta "A" ja "D" missä tahansa yhdistelmässä. Eli funktiot CDDDDR, CADARja CADDRniin edelleen ovat mahdollisia. Tällaisen funktion kutsuminen vastaa vastaavan funktiojoukon sijoittamista sisäkkäin CARja CDResimerkiksi (CADAR '((A B C) D E F))vastaa (CAR (CDR (CAR '((A B C) D E F))))ja palauttaa arvon "B". Tällaisten outojen toimintojen tarve liittyy usein toistuvaan tehtävään: poimia luettelosta tietty elementti, jonka sijainti tiedetään. HAITTOJA Ottaa pään ja hännän argumentiksi ja luo niistä luettelon tai pisteparin, jos argumentit ovat atomeja: (CONS 'A '(B C D)) ==>> (A B C D) — atomin liittäminen luetteloon; (CONS '(A B) '((C D))) ==>> ((A B) (C D)) - luettelon lisääminen toisen luettelon päähän; (CONS 'A 'B) ==>> (A . B) - kahden atomin pisteparin luominen. LISTA Tämä funktio palauttaa luettelon argumenteistaan: (list 1 3/7 'foo) ==>> (1 3/7 'foo) Jos argumentteja ei ole, palautetaan tyhjä lista: (list) ==>> NIL Jos jotkin elementit ovat lausekkeita, niiden arvo lasketaan ensin: (list 1 2 (list 1 2)) ==>> (1 2 (1 2)). LAINATA Järjestelmän operaattori QUOTEtukahduttaa argumenttinsa arvioinnin. Jos sitä ei käytetä, Lisp-tulkki, saatuaan luettelon tai symbolin syötteeseen, yrittää laskea sen: symbolille palautetaan sen arvo, luettelolle - tulos kutsuttaessa funktiota, jonka nimi on listan pää, parametrein - luettelon häntä. Jos on välttämätöntä, että tulkki ei laske arvoja, vaan ottaa symbolin tai luettelon "sellaisenaan", sovelle sitä QUOTE. (LIST 1 2 (QUOTE(LIST 1 2))) ==>> (1 2 (LIST 1 2)) (QUOTE (list 1 2 (list 1 2))) ==>> (LIST 1 2 (LIST 1 2)) Koska tukahduttaminen on hyvin yleinen operaatio, on syntaktinen sokeri , joka lyhentää sitä - QUOTE-kutsun täyden muodon sijaan voit laittaa lausekkeen eteen heittomerkin: (LIST 1 2 '(LIST 1 2)) ==>> (1 2 (LIST 1 2)). EVAL Tämä toiminto on itse asiassa Lisp-tulkki. QUOTEn vastakohtana se arvioi argumenttinsa arvon. (EVAL '(LIST 1 2 '(LIST 1 2))) ==>> (1 2 (LIST 1 2)) (EVAL '(LIST 1 2 (EVAL'(LIST 1 2)))) ==>> (1 2 (1 2)) Mahdollisuus kutsua tulkkia suoraan ja suoraan, yhdistettynä ohjelman rakenteen ja tietojen identiteetin kanssa, mahdollistaa kaikkien järjestelmän Lisp-ohjelmien luomisen ja suorituksen suoraan ilman rajoituksia. COND Yleistetty ehdollinen rakentaminen. Näyttää: (COND ((Условие1)(Выражение1)) ((Условие2)(Выражение2)) …) Ehto1, Ehto2 ja niin edelleen arvioidaan peräkkäin, kunnes seuraava ehtoN osoittautuu todeksi (alkaa olla arvo T). Sitten vastaava lausekeN suoritetaan ja sen arvo palautetaan kutsuarvona COND. Jos todellista ehtoa ei löydy, se CONDpalauttaa arvon NIL. On yleinen käytäntö asettaa viimeiseksi ehdoksi COND, Tjolloin varmistetaan, että jos kaikki muut ehdot epäonnistuvat, viimeinen lausekkeista arvioidaan; ELSEnäin luodaan imperatiivisten ohjelmointikielten ehdollisten operaattorien haaran analogi . DEFUN Rakenne, jonka avulla voit määrittää funktion. Yleinen (yksinkertaistettu) määritelmämuoto on seuraava: (DEFUN Имя (Параметр1 Параметр2 …) Выражение1 Выражение2 …) Tässä Nimi on funktion nimi. Vastaava symboli, jos sitä ei vielä ole, luodaan järjestelmään ja funktion määritelmä kirjoitetaan sen toimintopaikkaan. Jatkossa Lisp-tulkki, joka on tavannut nimen lasketun listan alussa, tulkitsee sen kutsuksi tälle funktiolle pyrstössä luetelluilla parametreilla. Parametri1 ja niin edelleen ovat funktion muodollisten parametrien nimiä. Sekvenssi Lauseke1, Lauseke2 ja niin edelleen on sarja laskettavia lausekkeita, jotka voivat käyttää parametreja ja yleisiä järjestelmämuuttujia. Kun funktiota kutsutaan funktioksi, lausekkeet arvioidaan peräkkäin ja funktion arvo palautetaan järjestyksessä viimeisen lausekkeen arvioimana arvona.Erikoisoperaattoreiden avulla voit hallita laskutoimituksia . Niiden avulla toteutetaan oksat ja silmukat . Operaattorin avulla voit arvioida toisen kahdesta lausekkeesta riippuen ehdon täyttymisestä, joka on myös lauseke. Jos sen tulos ei ole EPÄTOSI (ei ), ensimmäinen argumentti arvioidaan, muuten toinen. Esimerkiksi se palaa aina . ifnil(if nil (list 1 2 "foo") (list 3 4 "bar"))(3 4 "bar")
Lisp ei yleensä vaadi muuttujien, parametrien ja funktioiden tyyppien nimenomaista määrittelyä. Mutta tämä ei tarkoita, etteikö Lispissä olisi tyyppejä. Lisp käyttää dynaamista kirjoittamista , kun tietotyyppi ei viittaa muuttujaan (parametriin, funktioon), vaan arvoon . Tämä tarkoittaa, että muuttuja voi erityisten määritelmien puuttuessa sisältää minkä tahansa tietotyypin arvon ja eri aikoina sillä voi olla erityyppisiä arvoja. Arvotyypit määräytyvät sen mukaan, kuinka arvot luodaan. Esimerkiksi lausekkeessa (CONS 10 (CONS 2.01 (CONS 'A (CONS "abc" NIL))))samassa (ensimmäisessä) parametrissa sama funktio ( CONS) vastaanottaa peräkkäin kokonaisluvun , liukulukuluvun , atomin ja merkkijonon.
Edistyneissä nykyaikaisissa Lisp-järjestelmissä, mukaan lukien tavallinen Common Lisp, on suuri joukko sisäänrakennettuja tietotyyppejä, jotka on järjestetty hierarkkiseen järjestelmään, jossa tyypillä voi olla useita supertyyppejä ja useita alatyyppejä. Hierarkian juuri on sisäänrakennettu tyyppi T, kaikkien tyyppien supertyyppi, hierarkian viimeinen tyyppi on tyyppi NIL, kaikkien tyyppien alatyyppi.
Oikealla olevassa kuvassa näkyy fragmentti tästä hierarkiasta: numeeristen tyyppien arvojen supertyyppi on NUMBER, sen alatyypit - RATIONALja FLOAT, COMPLEX- edustavat vastaavasti rationaalilukua , liukulukua ja kompleksilukua , joista ensimmäinen on jolla puolestaan on alatyypit INTEGER( kokonaisluku ) ja RATIO( rationaalinen murtoluku ), toisessa - useita alatyyppejä, jotka edustavat liukulukuja vaihtelevalla tarkkuudella ja niin edelleen.
Ohjelmoijan luomat tyypit on myös rakennettu tähän järjestelmään.
Koska kaikki arvotyypit eivät kelpaa kaikille operaatioille, operaatioiden soveltaminen joihinkin arvoihin johtaa ajonaikaisiin virheisiin. Ohjelmoija voi joko jättää tämän ominaisuuden huomiotta (joka aiheuttaa ohjelman kaatumisen, jos ei-toivottua dataa kohtaa), tai käyttää poikkeusten käsittelyä tai tarkistaa, onko arvo, jolla hän aikoo työskennellä (esimerkiksi välitetty funktiolle parametrina) kuuluu haluttuun tyyppiin, ja mikäli mahdollista, valitse jokin muu tapa ratkaista ongelma tai muuntaa tiedot haluttuun tyyppiin. Tyyppien kanssa työskentelyyn on olemassa: tyypintarkistuspredikaatti TYPEP, tyypin määritystoiminto TYPE-OFja tyypin muunnokselle, jos se voidaan suorittaa, koko joukko erittäin erikoistuneita toimintoja ja yleinen toiminto COERCE. Tyyppitarkistusta helpottaa se, että Lispin tyyppijärjestelmä, kuten edellä mainittiin, on hierarkkinen. Mikä tahansa alatyypeistä on yhteensopiva minkä tahansa sen supertyypin kanssa. Esimerkiksi aritmeettiset operaatiot määritellään mille tahansa minkä tahansa tyyppisten lukujen yhdistelmälle, joten esimerkiksi summauksen käytön sallittavuuden kannalta riittää, että predikaatilla tarkistetaan TYPEP, että operandit ovat tyyppiä NUMBER.
( defun SmartPlus ( a b ) ( cond ( ( ja ( kirjoita a ' numero ) ( kirjoita b ' numero )) ( + a b )) ( t nolla )))Joten yllä olevassa esimerkissä SmartPlus-funktio palauttaa argumenttiensa summan, jos ne ovat minkä tahansa tyyppisiä lukuja, tai nollan, jos vähintään yksi niistä ei ole luku. Tässä tapauksessa tietty palautustyyppi riippuu parametrien todellisista tyypeistä:
( SmartPlus 1 2 ) ==> 3 ( tyyppi ( SmartPlus 1 2 )) ==> ( INTEGER 0 4611686018427387903 ) ( SmartPlus 1 1.2 ) ==> 2.2 ( tyyppi ( SmartPlus 1 1.2 ) LE ) -FLOAT ( SmartPlus 2 2/3 ) ==> 8/3 ( tyyppi ( SmartPlus 2 2/3 )) ==> SUHDE ( SmartPlus "abc" 20 ) ==> NIL ( tyyppi ( SmartPlus "abc ) " 20 )) ==> NULLDynaamisen kirjoittamisen käyttö ei ole aina kätevää, etenkään kääntäjää käytettäessä. Ensinnäkin, rajoitusten puuttuminen tyypeille, joihin muuttujan tai parametrin arvot voivat kuulua, heikentää kääntämisen tehokkuutta. Toiseksi, se ei salli staattisesti (kääntämisen, ei ohjelman suorituksen aikana) havaita virheitä, jotka liittyvät tyypin johdonmukaisuuden rikkomiseen. Tilanteissa, joissa nämä haitat ovat merkittäviä, Lisp sallii erikoisoperaattorin avulla DECLAREmäärittää parametrien ja muuttujien tyypit ja määrittää ne tarvittavalla tarkkuudella (voit määrittää sekä betonityypit, esimerkiksi RATIOtai SHORT-FLOAT, että minkä tahansa yleisyyden supertyypit, esimerkiksi NUMBER).
Lisp suunniteltiin alun perin toiminnalliseksi ohjelmointikieleksi, johon on otettu käyttöön tiettyjä välttämättömiä ominaisuuksia käytännön käytön helpottamiseksi. Valittu formalismi ja kielen perustana oleva primitiivisarja mahdollistivat kuitenkin sen laajentamisen eri suuntiin. Kielen vuosikymmenten toiminnan ja kehityksen aikana se on omaksunut lähes kaikki olemassa olevat ohjelmointimenetelmät ja sitä voidaan pitää tällä hetkellä yhtenä tehokkaimmista korkean tason moniparadigmakielistä.
Toiminnallinen paradigma on "syntyperäinen" Lispille, koska sen arkkitehtuurin perusta on Churchin lambda-laskenta . Itse asiassa Lispistä toiminnallinen ohjelmointi alkoi käytännön menetelmänä ohjelmistokehitykseen. Lambda-lausekkeet ovat täysimittaisia kieliobjekteja Lispissä, jotka mahdollistavat suoran kutsun lisäksi myös määrittämisen, tallennuksen symboliarvona, välittämisen kutsuparametrina ja palautuksen seurauksena. Siten Lisp tukee funktioita, eli funktioita, jotka ottavat parametreja ja palauttavat sen seurauksena muita toimintoja.
Eri Lisp-murteissa lähestymistapa funktioiden luonteeseen kieliobjekteina on hieman erilainen. Common Lispissä funktiot ja lambda-lausekkeet ovat erillinen luokka ohjelmaobjekteja, joille on erityisiä sääntöjä ja rajoituksia; Tämä tarkoittaa erityisesti sitä, että symbolilla on erilliset välit arvolle ja siihen liittyvälle funktiolle, ja tässä mielessä funktio ei ole täsmälleen sama kuin tietoelementti. Muissa murteissa, kuten T-Lisp tai Scheme, funktiot ovat niin sanottuja " täyskansalaisia " - ne voidaan vapaasti määrittää muuttujiin, välittää puheluparametreina ja palauttaa puhelutuloksina.
Nykyinen Lisp-standardi, Common Lisp, on arvosteltu "puhtaan" toiminnallisen ohjelmoinnin kannattajilta, koska kaikki sen toiminnot eivät ole teoreettisesti "puhdasta". Tämä on totta, koska Common Lisp suunniteltiin yleismaailmalliseksi teolliseksi kieleksi, ja useissa tapauksissa käytännön tarkoituksenmukaisuutta koskevat näkökohdat asetettiin tarkoituksella teoreettisen puhtauden huomioiden edelle. Siitä huolimatta Lisp oli ja on edelleen toimiva ohjelmointikieli.
Aluksi Lisp-syntaksilla on kyky kuvata algoritmeja luettelemalla vaadittujen toimien sarja. Se piilee ns. "implisiittisessä PROGN:ssa", jota tuetaan Lispin lambda-kutsujen rakenteessa: paikkaan, johon lambda-lausekkeen perustana oleva komento tulisi sijoittaa, ei voida kirjoittaa yhtä, vaan useita komentoja, ja lambda-kutsun tulos on niistä viimeinen. Siten Lisp tukee implisiittistä peräkkäistä toimintojen suorittamista. Implisiittisen PROGN:n lisäksi tuetaan eksplisiittisiä pakottavia mekanismeja pakolliseen ohjelmointiin:
Common Lisp on erityinen paikka LOOP-järjestelmämakrossa. Sen avulla voit luoda fragmentin Lisp-ohjelmassa, joka on kirjoitettu ohjelmointikielellä tavanomaisella imperatiivisella rakenteella ja operaattorien infix-merkinnällä.
Yksinkertaisin makro-ohjelmointitoiminto, joka on saatavilla missä tahansa Lisp-toteutuksessa, on kyky kutsua tulkki ( EVAL -funktio ) suoraan ja välittää sille ohjelmana mikä tahansa listarakenne. Tämän ansiosta huipputason ohjelma voi toimia makrogeneraattorina, eli luoda suoritettavaa koodia, joka suoritetaan myöhemmin. Esimerkiksi:
( defun nimi ( nimi lv ) ( eval ( cons 'defun ( cons name ( cdr lv ))))) ( nimi 'add ' ( lambda ( x y ) ( + x y ))) ( lisää 5 7 ) ==>12Tässä funktio назватьrakentaa sille siirretystä nimestä ja lambda-lausekkeesta uuden funktiomäärityksen ja suorittaa tämän määritelmän sitten eval. Tämän seurauksena uusi funktio (tässä esimerkissä funktio сложить) ilmestyy järjestelmään ja sitä voidaan kutsua tavalliseen tapaan.
Tätä ominaisuutta käytetään kuitenkin harvoin sen vaivallisuuden vuoksi. Makrojärjestelmää käytetään paljon yleisemmin . Lispin nykyaikaisissa muunnelmissa, mukaan lukien Common Lisp -standardi, on edistyneitä ominaisuuksia makrojen luomiseen ja käyttämiseen . Makromäärittely Lispissä on syntaktisesti samanlainen kuin funktion ilmoitus (ainoa ero on defmacro-avainsanan käyttö defunin sijaan), mutta makron käyttäytyminen on huomattavasti erilainen: jokainen makron kutsu on "laajentunut". kun ohjelma käännetään, luo koodi, joka ajon aikana suoritetaan seuraavasti: ikään kuin se olisi kirjoitettu suoraan soittopaikassa. Toinen ero makrojen ja tavallisten funktioiden välillä on se, että niiden argumentteja ei arvioida oletusarvoisesti. Yllä olevan esimerkin toteutus makrona voisi näyttää tältä:
( defmakron nimi ( nimi lv ) ( cons 'defun ( cons name ( cdr lv )))) ( nimi add ( lambda ( x y ) ( + x y ))) ( lisää 12 8 ) ==>20Näkyviä eroja on kaksi: makromäärittelyssä ei ole kutsua evalja parametreja edeltäviä heittomerkkejä ei käytetä kutsussa, koska makroparametreja ei arvioida. Mutta toinen ero on paljon tärkeämpi: jos ensimmäisessä esimerkissä uuden funktion rakentaminen tapahtuu ohjelman suorituksen aikana, makron laajennus suoritetaan ohjelman kääntämisen aikana, jotta kääntäjä saa mahdollisuuden käsittele funktiota сложить. Syntaksivirheet makrojen funktioiden muodostamisessa ei myöskään havaita ohjelman suorituksen aikana, vaan jopa käännösvaiheessa.
Lisäksi useat Lisp-toteutukset tukevat niin kutsuttujen "lukumakrojen" luomista – makroja, jotka muuttavat suoraan ohjelman tekstiä. Makron avulla voit määrittää avoimesti uusia kielirakenteita ja jopa laajentaa kielen syntaksia. Jälkimmäistä mahdollisuutta käytetään aktiivisesti toteutettaessa Lispissä menetelmiä ja ohjelmointityökaluja, joita siinä ei alun perin tueta.
Lispiä ei ole suunniteltu oliokieliksi. Itse olio-ohjelmointiparadigma kehitettiin puolitoista vuosikymmentä myöhemmin kuin Lisp, mutta kun se ilmestyi ja tuli suosituksi, objektiominaisuudet lisättiin tähän kieleen.
Lispin ydinominaisuus tekee olio-alijärjestelmän lisäämisen Lispiin paitsi mahdollista myös helppoa. Symbolien ominaisuuksien (paikat) vuoksi Lisp tukee natiivisti kapselointia . Lispin toiminnalliset ominaisuudet (funktionaalien tuki, funktioiden määrittäminen muuttujille ja niiden tallentaminen symboliominaisuuksiin) mahdollistavat koodin (menetelmien) liittämisen dataan (objekteihin). Lopuksi kielen dynaaminen luonne yhdistettynä yllä oleviin ominaisuuksiin varmistaa koodin ja datan polymorfisen käyttäytymisen ohjelmassa. Ainoa OOP-järjestelmän komponentti, jota ei löydy perus-Lispistä, on periytyminen, mutta se voidaan toteuttaa ilman vaikeuksia. Siten Lisp sisältää kaikki elementit, joihin OOP-teknologia perustuu, ja sen tuen toteuttaminen kielellä rajoittuu vastaavien syntaktisten elementtien luomiseen. Kehitetyn makromekanismin ansiosta niitä voidaan lisätä käyttämällä itse kieltä ilman, että perussyntaksia tarvitsee laajentaa ja kääntäjiä muokata. Yksinkertainen ja tyylikäs esimerkki oman OOP-alijärjestelmän luomisesta Lispissä löytyy Paul Grahamin ANSI Common Lispistä [6] .
Lispin kaupallisesti tunnetuista olio-laajennuksista mainittakoon ensinnäkin Flavours-objektialijärjestelmä, joka sisältyi Zetalysp-järjestelmään. Tämä alijärjestelmä tarjosi luokkailmoitukset (maut), yksi- ja moniperinnön, polymorfiset luokkamenetelmät, Smaltalk-tyyppisen objektien vuorovaikutusjärjestelmän sanomanvälityksellä (toteutettu oliomenetelmäkutsuna). Toinen esimerkki on LOOPS (Lisp Object-Oriented Programming System), objektialijärjestelmä, joka toteutettiin vuonna 1983 Interlisp-murteella.
CLOS ( Common Lisp Object System) -objektijärjestelmä, joka luotiin alun perin Common Lispin lisäksi ja sisällytettiin myöhemmin kielistandardiin, on samanlainen kuin Flavours ja tukee olennaisesti samoja ominaisuuksia, jotka ovat vakiona lähes kaikissa moderneissa oliokielissä. . Olioohjelmoinnin käyttö Lispissä liittyy pääasiassa mallinnus- ja/tai ohjausongelmien ratkaisemiseen, jotka luonteeltaan onnistuneesti yhdistetään olioteknologiaan. Esimerkiksi yksi Flavours-järjestelmän ensimmäisistä sovelluksista oli vuorovaikutus moniikkunaisen käyttöliittymän kanssa, joka on juuri sopiva mallinnettavaksi joukkona viestintäobjekteja.
Lispin kirjoittaja on John McCarthy , joka työskenteli kielen luomisen aikaan Massachusetts Institute of Technologyssa (MIT) viestinnän professorina . Hän työskenteli yhdessä Marvin Minskyn kanssa tekoälyn parissa, jonka yhteydessä oli tarpeen luoda ohjelmointikieli, joka soveltui tällä alueella ratkaistaviin tehtäviin. McCarthy työskenteli kielten luomisessa MIT:ssä vuosina 1958–1963 , minkä jälkeen hän muutti Stanfordin yliopistoon Kaliforniaan, missä hän sai "tekoälyn professorin" paikan.
Lisp perustui Newellin, Shawin ja Simonin kehittämään varhaiseen IPL -kieleen. IPL oli listankäsittelykieli, ja sen tarkoituksena oli toteuttaa Logic Theorist -projekti, tekoälyjärjestelmä, joka on suunniteltu johtamaan automaattisesti matemaattisen logiikan lauseita. IPL oli melko matalan tason kieli, mutta se toteutti jo sellaisia perusideoita yhtenä mekanismina ohjelmien ja tietojen tallentamiseksi luetteloiden muodossa - linkeillä linkitettyjen elementtien hierarkkisia rakenteita (aito tiedon listaesittelystä lainattiin psykologian ja assosiatiivisen muistin tutkimuksesta) sekä ajatus dynaamisesta muistin allokoinnista. Tutustuttuaan IPL:ään vuonna 1956 McCarthylla oli idea toteuttaa IPL- listakäsittely Fortranissa , jota suunniteltiin tuolloin IBM:ssä (ja saman IBM 704 -järjestelmän alla , jonka kanssa McCarthy työskenteli MIT:ssä), mutta tämä ajatus on ei ole pantu täytäntöön. McCarthy osallistui myöhemmin Algolia kehittäneen "korkean tason kielikomitean" työhön , mutta sielläkin hänen ehdotuksensa otettiin kylmästi vastaan. Tämän seurauksena McCarthy keksi ajatuksen uuden ohjelmointikielen luomisesta.
Aluksi McCarthy muotoili listaformalismin datan kuvaamiseen ( S-lausekkeet ) ja siihen perustuvan lambda-lausekkeiden kuvaamismekanismin , mikä mahdollisti ohjelmien kirjoittamisen listamuodossa esitettyinä funktiojoukkoina. Kuten McCarthy myöhemmin kirjoitti, hän suunnitteli alun perin käyttävänsä ohjelmien kirjoittamiseen erillistä, S-lausekkeista poikkeavaa formalismia, mutta tämä osoittautui tarpeettomaksi. Kun McCarthy kuvaili listamerkintäään käyttäen, kuinka uuden kielen tulkki toimisi (formalismi, joka tulee tunnetuksi nimellä "Lisp on Lisp"), Steve Russell huomasi, että nyt todellisen toimivan tulkin luomiseen riittää pelkkä kääntääksesi tämän merkinnän konekoodiksi. McCarthy suhtautui tähän ideaan skeptisesti, mutta Russell todella teki tämän työn ja hankki ensimmäisen Lisp-tulkin IBM 704 -tietokoneeseen. Myöhemmin ajatusta kielenkääntäjän kirjoittamisesta Lispille käytettiin toistuvasti, ei vain toiminnallisissa ja loogisilla kielillä, mutta myös pakollisilla kielillä.
Historiallisesti ensimmäinen Lisp-toteutus, joka sisälsi kaikki nykyaikaiset kielen peruselementit, oli IBM 704:llä toimiva tulkki, joka ilmestyi lokakuussa 1958. Tämä muuten antaa meille mahdollisuuden puhua Lispistä yhtenä kahdesta vanhimmista korkean tason kielestä, jotka ovat olleet käytössä luomishetkestä nykypäivään (ensimmäinen on Fortran). Lisäksi Lisp säilytti johtoasemansa toisessa suhteessa. Tosiasia on, että aktiivinen työ dynaamisten luetteloiden kanssa teki mahdottomaksi manuaalisen hallinnan muistia, joka on osittain säilynyt pakollisissa kielissä tähän päivään asti. Uusien listasolujen ja listojen luominen ja olemassa olevien Lisp-ohjelmien käytöstä poistuminen ovat niin aktiivisia, että on lähes mahdotonta tulla toimeen ilman automaattista muistinhallintajärjestelmää, joka ohjaisi aiemmin muistiin luotujen objektien käyttöä ja poistaisi ajoittain niitä. ne, jotka ovat lopettaneet käytön eli jätteenkeräysjärjestelmät . McCarthy joutui toteuttamaan tämän järjestelmän, jolloin Lispistä tuli muun muassa myös vanhin nykyään käytössä oleva ohjelmointikieli automaattisen muistinhallinnan ja roskienkeräyksen kanssa.
Myöhemmin tehtiin toteutuksia IBM 7090:lle ja myöhemmin IBM 360- ja 370-sarjoille. IBM-tietokoneet osoittautuivat hankalaksi työskennellä interaktiivisessa tilassa, minkä seurauksena 1950-luvun lopulla pieni joukko kehittäjiä mukaan lukien ne, jotka olivat aiemmin työskennelleet IBM:llä ja erotettiin itsenäiseksi yritykseksi Digital Equipment Corporation (DEC). Sen ensimmäinen tuote oli PDP-1- tietokone , joka alun perin keskittyi interaktiiviseen toimintatilaan. Tälle koneelle otettiin vuonna 1960 käyttöön vuorovaikutteinen Lisp 1 -järjestelmä, joka sisältää integroidun tulkin, lähdekoodieditorin ja virheenkorjaajan, mikä mahdollisti ohjelman koko työsyklin suorittamisen suoraan järjestelmässä. Itse asiassa se oli ensimmäinen "ohjelmointiympäristö" siinä mielessä, joka nyt sisällytetään tähän konseptiin. Samaan aikaan McCarthyn artikkeli "Recursive Functions of Symbolic Expressions and their Computation by Machine" julkaistiin Communications of ACM -lehdessä, jossa Lisp kuvattiin itse Lispin algebraliseksi formalismiksi. Artikkelista tuli klassikko, ja "Lisp on Lisp" -formalismista on sittemmin tullut yksi eniten käytetyistä ohjelmointiteorian kirjallisuudessa. Toinen "Lisp 1" -järjestelmän käyttöönoton yhteydessä ilmestynyt tekninen innovaatio oli McCarthyn keksimä mekanismi, joka antoi Lisp-tulkin toimia samanaikaisesti normaalin laskennallisen työn suorittamisen kanssa erätilassa (mitä nykyään kutsutaan " aikajakojärjestelmä").
Vuoteen 1962 mennessä alkuperäisen Lisp-järjestelmän seuraava versio "Lisp 1.5" oli valmis, jossa ensimmäisen version toiminnan aikana havaitut puutteet poistettiin. Hänen kuvauksensa julkaisi MIT Press erillisenä kirjana [7] . Koska käsikirja sisälsi kuvauksen järjestelmän toteutuksesta, siitä tuli perusta Lisp-järjestelmien luomiselle monille muille tietokoneille sekä Yhdysvalloissa että ulkomailla.
Huolimatta Lispin joskus melko aktiivisesta käytöstä Euroopan ja Aasian maissa ja omien Lisp-järjestelmien luomisesta siellä, suurin osa Lispin yleisimmistä murteista on peräisin Yhdysvalloista.
Mac Lisp1960-luvun alusta lähtien MIT:ssä käynnistettiin MAC-projekti, jonka puitteissa MacLisp kehitettiin Lisp 1.5:een perustuen pääasiassa PDP-tietokoneisiin. MacLisp oli aikansa erittäin tehokas, sillä siinä oli korkea laskentateho ja laaja valikoima matemaattisia tietotyyppejä, mukaan lukien vektorit, matriisit ja bittikentät. Osana panosta itse kielen kehittämiseen voidaan huomata MacLispissä ilmestyneet lukumakrot ja lukutaulukot, jotka mahdollistivat kielen "viimeistelemisen" laajentaen sitä oikeaan suuntaan uusilla rakenteilla. Poikkeuskäsittely- ja rinnakkaiskäsittelylaitteet sisällytettiin myös kieleen. MacLispistä tuli myös ensimmäinen Lisp - järjestelmä , jolle otettiin käyttöön erittäin tehokas kääntäjä .
Tietokonealgebrajärjestelmä Macsyma on kirjoitettu kokonaan MacLispillä , jonka kehittäminen aloitettiin osana MAC-projektia vuonna 1968. Macsyma pysyi lajissaan edistyneimpana järjestelmänä useiden vuosien ajan, ja useita Lispin murteita luotiin erityisesti siirtämään Macsyma muille alustoille. Toinen erittäin kuuluisa ja edelleen käytössä oleva ohjelmisto, joka alun perin kehitettiin MacLispissä, on koko näytön tekstieditori Emacs .
MacLisp-järjestelmää hyödynnettiin ja kehitettiin 1980-luvulle saakka, mikä vaikutti merkittävästi 1960-1980-luvuilla ilmestyneisiin Lispin toteutuksiin, mukaan lukien siitä, että siitä tuli yksi Common Lisp -standardin suunnittelun lähteistä. Järjestelmän toiminta käytännössä loppui 1980-luvulla, kun sen alunperin perustana olevien PDP-10/20-tietokoneiden käyttö lopetettiin. MacLispillä ja jo mainituilla Macsymalla ja Emacsilla kehitetyt järjestelmät ovat säilyneet paljon .
InterlispMonet yritykset ja tutkimuskeskukset Yhdysvalloissa osallistuivat Lisp-järjestelmien kehittämiseen 1960-luvun puolivälissä. Interlisp syntyi BBN:n (Bolt, Beranek ja Newman Inc.), SDS:n (Scientific Data Systems) ja Xeroxin yhteisten ponnistelujen tulos. BBN Research Center aloitti vuonna 1966 PDP-10- ja SDS-930-tietokoneisiin keskittyneen Lisp-toteutuksen luomisen. BBN-Lispin PDP-versiossa käytettiin laitteistohaku- ja kontekstinvaihtomekanismia, joka on erityisesti suunniteltu tarjoamaan erittäin tehokas ajanjako. BBN-Lispistä tuli suosittu tekoälytutkijoiden keskuudessa ja se vaikutti suuresti siihen, että PDP-10/20-koneet pysyivät tekoälytyön päätyökaluina 1980-luvulle asti. 1970-luvun alussa Xerox Corporation osti konkurssiin menneen SDS:n ja solmi kumppanuuden BBN:n kanssa. Vaikka SDS-koneet eivät olleet kovin kaupallisesti menestyneitä, BBN:n Lisp-toteutus oli tarpeeksi lupaava Xeroxille tukemaan sen jatkokehitystä, jolloin BBN-Lispistä tuli Interlisp .
Ja vuonna 1974 Xerox alkoi kehittää henkilökohtaista Alto-työasemaa, joka oli alun perin suunnattu Lispille. Tässä järjestelmässä tehtiin ensimmäistä kertaa laitteiston ja konekäskyjärjestelmän kehittäminen tietylle ohjelmointikielelle. Interlispin pohjalta luotiin yksinkertaistettu versio Interlisp-D-järjestelmästä, joka on suunniteltu 1100-sarjan Lisp-koneille (Alton aseman "jälkeläisille"). Nämä koneet ottivat ensimmäisinä käyttöön moniikkunaisen graafisen käyttöliittymän, käyttivät korkearesoluutioista grafiikkaa ja käyttivät hiirtä.
Järjestelmä dokumentoitiin laajasti, ja se sisälsi hyvin suunnitellun IDE:n, jossa oli lähdekoodieditori, virheenkorjausohjelma, tulkki ja monia kehittäjäapua, ja siitä tuli yksi esimerkillisistä ohjelmointiympäristöistä aikajakojärjestelmille. Yli 500 toimintoa toteutettiin järjestelmäkirjastoissa, järjestelmässä oli suuri määrä asetuksia, jotka mahdollistivat sen "räätälöinnin" käyttäjälle. Interlisp-toteutukset ajettiin lopulta eniten käytetyillä aikajakokäyttöisillä suurilla tietokoneilla.
Itse kielestä voidaan todeta, että murre kaikkine ominaispiirteineen vakiintui jo 1970-luvun puolivälissä, minkä jälkeen kieleen ei tehty perusteellisia muutoksia. Tämä aiheutti sen, että järjestelmä jäi toiminnallisuudessa jälkeen uudemman kehityksen jälkeen ja korjasi joitakin vanhentuneita suunnittelupäätöksiä. Tämän seurauksena Interlispillä oli 1980-luvun alussa vaikeuksia sekä yhteensopivuuden kanssa uusien järjestelmien kanssa että laajentumisen kanssa. Merkittävimmät puutteet ovat tietotyyppien, objektien ja sulkemisten hierarkian puute (kuitenkin vuonna 1983 otettiin käyttöön LOOPS-oliojärjestelmä, joka antoi mahdollisuuden olio-ohjelmointiin). Vielä tärkeämpää on, että Interlisp perustuu dynaamiseen linkitykseen, kun taas kaikki Lispin uudet versiot ovat staattisia.
PSLLisp tuli Kaliforniaan McCarthyn kanssa, joka muutti Stanfordiin vuonna 1963. Seuraavien vuosien aikana kehitettiin Lisp 1.6 ("klassisen" Lisp 1.5:n suora jälkeläinen), UCI Lisp (University of California, Irvine) ja Stanford Lisp/360 -järjestelmät. Sieltä Lisp meni yhdessä Anthony Hearnin kanssa Utahin yliopistoon , jossa hän teki tutkimusta symbolisen matematiikan alalla teoreettisen fysiikan sovelluksissa. Hearn ehdotti näiden ongelmien ratkaisemista Lispin avulla, mikä johti tietokonealgebrajärjestelmän Reducen luomiseen vuonna 1968 .
Hearn julkaisi Standard Lisp -määrityksen vuonna 1966, jota hän ehdotti kielen standardoinnin perustaksi. Hänen ehdotuksensa ei saanut kannatusta, koska tekoälytutkijat eivät hyväksyneet sitä, koska he toivat esiin useita heille ei-toivottuja piirteitä ehdotetusta standardista, erityisesti liiallisen tyyppeihin sitoutumisen. Tämän spesifikaation perusteella Portable Standard Lisp, PSL, otettiin kuitenkin käyttöön Utahissa. Tätä toteutusta käytettiin Reducen kehittämiseen ja portaamiseen eri laitteistoalustoille. Erityisesti siirrettävyyden parantamiseksi PSL:ään on sisällytetty pienempi joukko järjestelmän toimintoja ja rakenteita. Toteutus perustui keskitason matalan tason Lisp-kaltaiseen kieleen, SYSLisp; PSL-ydin oli kirjoitettu SYSLisp-kielellä ja muu osa järjestelmästä itse PSL:llä. PDP-10:een toteutettiin SYSLisp-kääntäjä ja samaan SYSLisp-kieleen kirjoitettu ristikääntäjä, jonka avulla PSL-ydin voitiin siirtää mihin tahansa muuhun laitteistoon. Tämän tekniikan avulla PSL ja Reduce on toteutettu useilla alustoilla, mukaan lukien DEC-10/20, VAX/UNIX, HP9000, Apollo, Wicat, IBM, Cray.
Siten PSL:stä tuli yksi ensimmäisistä esimerkeistä "spin-up"-tekniikan toteutuksesta siirrettäessä ohjelmistojärjestelmiä uuteen arkkitehtuuriin, kun järjestelmän siirtämistä varten ydin kirjoitetaan alun perin koneista riippumattomalla välikielellä. , jolle puolestaan luodaan toteutuksia kaikille kohdealustoille. PSL:n lisätukea suoritti Kalifornian Hewlett-Packardin tutkimuskeskus.
Franz LispFranz Lispin motivaatio 1970-luvun lopulla oli hankkia Lisp-järjestelmä uusiin VAX-tietokoneisiin Macsyma-järjestelmän ja muiden Lisp-kirjoitettujen ohjelmistojen käyttämiseksi. Koska päätavoitteena oli Macsyman portaaminen, otettiin MACLisp perustaksi, mutta joitakin vanhentuneita ominaisuuksia poistettiin kielestä ja lisättiin uusia mekanismeja, jotka lainattiin tuolloin samassa MIT:ssä kehitellyltä Zetalispilta. Merkittävimmät panokset tämän murteen luomiseen antoivat Berkeleyn yliopisto , Pennsylvanian yliopisto , Bell Labs , Livermore National Laboratory ja Carnegie Mellon University . Yksi projektin tärkeimmistä inspiraation lähteistä oli Berkeleyn yliopiston professori Richard Feitman, joka oli entinen MIT:stä ja osallistui alkuperäisen Macsyma-järjestelmän kehittämiseen. Franz Lispin luojien joukossa oli useita hänen oppilaitaan. Järjestelmän nimi valittiin kuuluisan unkarilaisen säveltäjän Franz Lisztin (englanninkielinen oikeinkirjoitus: Franz Liszt) kunniaksi.
Järjestelmä otettiin käyttöön vuonna 1981 C : ssä VAX 780/11 :lle, jossa on UNIX . Järjestelmään sisältyvä kääntäjä oli nimeltään "Liszt" - murteelle nimen antaneen säveltäjän sukunimi. Vuonna 1982 järjestelmä siirrettiin Motorola 68000 -prosessoriin ja sitten useisiin 32-bittisiin henkilökohtaisiin alustoihin, minkä seurauksena siitä tuli laajimmin käytetty Lisp-versio sekä 32-bittisille aikajakojärjestelmille että 32-bittisille minitietokoneille. ja henkilökohtaiset työasemat.
Franz Lispia jaettiin ilmaiseksi BSD-lisenssillä, mutta Berkeleyn jatko-opiskelija Friedrich Kunze keksi idean perustaa kaupallinen yritys, joka tarjoaisi laadukasta maksullista käyttäjätukea ja toteuttaisi tilaukset Franz Lispin siirtämisestä uusiin laitteisiin ja ohjelmistoalustoille. Se oli aktiivisen kasvun aikaa tietokonemarkkinoilla ja näkymät näyttivät hyviltä. Yritys rekisteröitiin vuonna 1984 ja sen nimeksi tuli Franz Inc. Yrityksen toiminnan alku oli varsin onnistunut, hän onnistui saamaan sopimuksen Franz Lispin siirtämisestä Sun-alustalle ja myöhemmin - useita muita vastaavia tarjouksia. Kuitenkin vuonna 1985 Yhdysvaltain puolustusministeriön painostuksesta amerikkalainen Lisp-yhteisö aloitti aktiivisen uudelleensuuntautumisen kohti uutta murretta - Common Lisp -kieltä, joka oli tuolloin valmistumassa. Näissä olosuhteissa Franz Inc. ei löytänyt uusia sopimuksia, oli sulkemisen partaalla ja joutui siirtymään kehittämään omaa Common Lisp - Allegro Common Lisp -toteutusta (nimi valittiin "musiikkiteeman" jatkuvuuden säilyttämiseksi). Franz Lispin historia itse asiassa päättyi tähän. Alkuperäinen järjestelmä on nyt kokonaan pois käytöstä.
SchemeScheme-kieli kehitettiin vuonna 1976 MIT:ssä osana Lisp Machine -projektia, henkilökohtaista työasemaa, joka on suunniteltu kokonaan laitteistosta hyödyntämään Lisp-kieltä. Aluksi Scheme oli vain "tutkimuskieli", jonka kehittämisen aikana testattiin erilaisia ideoita ja menetelmiä. Tavoitteena oli toteuttaa vähimmäissarja perusominaisuuksia, jotka varmistaisivat täysimittaisen Lisp-järjestelmän rakentamisen tälle sarjalle rakentamalla.
Tuloksena on pieni ja tyylikkäästi määritelty ydin, mutta erittäin tehokkaasti toteutettu. Erityisesti Scheme oli ensimmäinen Lispin murre, joka takasi tail-rekursion optimoinnin. Kieli toteuttaa tehokkaan makromekanismin, listojen lisäksi taulukoita tuetaan perusrakenteina. Tyypillinen syntaktinen ero Schemen ja useimpien Lisp-murteiden välillä on hieman erilainen funktion määritelmä. Jos useimmissa murteissa käytetään muunnelmaa: (DEFUN ИмяФункции (Аргументы) Выражения), niin Kaaviossa määritelmän lyhennetty muoto näyttää tältä (DEFINE (ИмяФункции Аргументы) (Выражения)). (Avainsana ja funktion nimen ja argumenttien suhteellinen sijainti eroavat toisistaan). Scheme käyttää dynaamista linkitystä ja toteuttaa yhden nimitilan funktioille ja muuttujille, mikä erottaa sen Common Lispistä.
Scheme on Lispin ainoa "vanha" murre, jota käytetään edelleen Lisp-yhteisön laajan siirtymisen jälkeen standardoituun Common Lispiin. Tällä hetkellä Schemillä on useita tuettuja toteutuksia, mukaan lukien ilmaiset, on esimerkkejä tämän kielen käyttämisestä sisäänrakennettuna (esimerkiksi GIMP Tiny-Scheme -skriptityökaluna). Useat amerikkalaiset yliopistot käyttävät Schemeä ohjelmoinnin perusopetuksen kielenä.
ZetalispZetalisp eli "Lisp Machine Lisp" luotiin MIT:ssä 1970-luvun toisella puoliskolla osana amerikkalaisen puolustusviraston DARPAn rahoittamaa Lisp Machine Projectia.
Järjestelmä perustui MacLispiin ja Emacs-editoriin, mutta kieltä päivitettiin ja täydennettiin merkittävästi, erityisesti siihen ilmestyi uusia tietotyyppejä, Flavours-olio-alijärjestelmä, jossa ohjelmien vuorovaikutus moniikkunaisella käyttöliittymällä perustuu, uudet, osittain Interlispistä lainatut direktiiviohjausrakenteet, moniarvoiset funktiot (pystyvät palauttamaan useamman kuin yhden arvon tavallisella tavalla ilman, että niitä ensin "kokoaa" säilöön), suoratoisto I/O, nimiavaruudet, tehokas kirjasto funktioista, mukaan lukien matemaattiset, vektori- ja matriisilaskelmien tarjoaminen ja lineaaristen järjestelmien kanssa työskentely.
Itse ohjelmointijärjestelmään tehtiin paljon enemmän innovaatioita. Järjestelmä oli alun perin suunniteltu toimimaan graafisen käyttöpäätteen ja hiiren kanssa. Se toteutti graafisen moniikkunaisen käyttöliittymän. Järjestelmä sisälsi moniikkunaisen Lisp-tulkin, osittaisen kääntäjän, Zmacs-tekstieditorin, tietorakenteen tarkastajan, debuggerin, järjestelmän tilan tutkijan, järjestelmätiedostoeditorin, fonttieditorin ja Zmail-sähköpostiohjelman. Järjestelmä sisälsi muiden korkean tason kielten kääntäjiä, Interlisp-ohjelmia tukevan muuntimen ja joukon korkeamman tason työkaluja. Järjestelmän osana toimitetuissa Fortranissa, Pascalissa, Adassa ja Prologissa kehitettiin vuorovaikutuskeinoja Lisp-ohjelmien kanssa, jotka mahdollistivat tarvittaessa ohjelmistojärjestelmien kehittämisen ja soveltamisen useilla kielillä.
Aluksi hankkeen tavoitteena oli kaupallisen tuotteen luominen. Vuonna 1979 perustettiin kaksi yritystä - Lisp-koneiden valmistajat: Symbolics ja Lisp Machine Inc. (LMI). Sen jälkeen nämä yritykset suorittivat itsenäisesti Zetalispin kehittämistyön. Vaikka itse Lisp-koneissa oli eroja, ne olivat kielen suhteen lähes täysin yhteensopivia.
NIL ja TMACLispin käyttöönotto MIT:n VAX-koneessa alkoi vuonna 1979. Projektin nimi oli NIL (samaan aikaan lyhenne "New Implementation of Lisp" - "New Lisp Implementation" - ja standardi Lisp-atomi "NIL", mikä tarkoittaa käyttötarkoituksesta riippuen loogista epätotuutta tai tyhjää listaa). NIL:ssä oli melko suuri, VAX assemblerilla kirjoitettu ydin, jolle Lisp-järjestelmä rakennettiin samalla purkausmenetelmällä. Jossain määrin NIL:ää voidaan pitää "vastauksena Franz Lispille", koska yksi projektin tavoitteista oli sama Macsyma-järjestelmän siirtäminen VAX:iin. NIL lainasi paljon Zetalispilta, mukaan lukien Flavours-järjestelmän, joka muuttaa Lisp-järjestelmän oliokeskeiseksi. Vuonna 1981 NIL-projektissa mukana ollut ryhmä hajosi luotavan järjestelmän ideologian sovittamattomien erimielisyyksien vuoksi. Romahduksesta huolimatta järjestelmään on vuodesta 1982 lähtien julkaistu säännöllisiä päivityksiä ja se on saanut melko huomattavan jakelun. 1980-luvulla NIL:ää käytettiin usein organisaatioissa, joissa oli sekä VAX- että Lisp-koneet, koska NIL:n ja Zetalispin välillä ei ole perustavanlaatuisia ideologisia eroja, vaikka Zetalisp onkin paljon rikkaampi ominaisuuksia.
Ryhmä kehittäjiä, jotka erosivat NIL-projektista, alkoivat luoda omaa versiotaan Lisp-järjestelmästä, joka sai ironisen nimen " T " (samaan aikaan - sanoista "True Lisp" - "Real (true) Lisp" ja toinen standardi Lisp-atomi "T", joka tarkoittaa loogista totuutta, toisin sanoen "NIL":n vastakohtaa). Tämän murteen kehittäminen toteutettiin Yalen yliopistossa vuosina 1982-1984. Toisin kuin "vanhoissa" järjestelmissä, T-murteessa käytettiin oletusarvoisesti staattista muuttujien sidontaa, lisäksi sen luojat ottivat käyttöön funktioiden toteutuksen "täyskansalaisina", mikä tarkoittaa, että funktioita voidaan osoittaa muuttujille ilman erityisiä syntaktisia keinoja ja ilman rajoituksia ja palautetaan muiden funktioiden arvoina. T-Lispillä, toisin kuin NIL:llä, oli melko pieni konekielellä kirjoitettu ydin. Kehittäjät käyttivät "spin-up" -tekniikkaa, siirtäen ytimen manuaalisesti uusille alustoille ja toteuttaen muun järjestelmän suoraan Lispissä, sillä odotuksella, että erittäin tehokas kääntäjä tarjoaisi paremman suorituskyvyn lopulliselle järjestelmälle kuin suuren koneen manuaalinen käyttöönotto. kielen ydin.
T-Lispissä kiistanalainen kohta oli tekijöiden päätös päivittää ja systematisoida järjestelmätoimintojen nimet. Joten esimerkiksi kaikkien predikaattien nimet poikkeuksetta päättyivät kysymysmerkkiin, alkeisfunktioiden "historiallisesti vakiintuneet" vakionimet korvattiin muistonimillä, jotka vastaavat funktion toimintaa. Esimerkiksi funktiot CARja CDR, jotka palauttavat luettelon pään ja hännän, on nimetty FIRSTja REST(eng. "first" ja "remainder"). Tämän päätöksen kiistaton etu oli oppimisen helpottaminen, ilmeinen haittapuoli oli yhteensopimattomuus kaikkien muiden kielen murteiden kanssa. Tästä johtuen tekijöiden oli vielä myöhemmin täydennettävä järjestelmää makroilla, jotka saattavat nimeämisjärjestelmän Common Lisp -standardin mukaiseksi. Varmasti merkittävä vaikutus, joka Schemen murteella on ollut T. Yleisesti ottaen T-Lisp osoittautui melko yksinkertaiseksi, tyylikkääksi ja mobiiliksi järjestelmäksi, joka toteutettiin VAX:lle ja siirrettiin monille 32-bittisille työasemille.
1980-luvun ensimmäisellä puoliskolla Lisp-yhteisössä oli kehittynyt tilanne, että jotkut kirjoittajat vertasivat Baabelin torniin : yli tusina Lispin suurta murretta oli olemassa ja kehittynyt rinnakkain, kun taas toteutusten kokonaismäärä oli ristiriidassa keskenään. oli huomattavasti suurempi. Samanlainen tilanne havaittiin tuolloin useimmissa yleisissä ohjelmointikielissä, mutta Lispin tapauksessa tilannetta pahensi se, että kieli oli alun perin suunniteltu mielivaltaisesti laajennettavaksi, mikä provosoi sen kykyjen kehittymistä eri murteissa merkittävästi eri suuntiin. Jos alkuvaiheessa, kun Lispiä käytettiin lähes yksinomaan laboratorioissa ja instituuteissa, murteiden monimuotoisuus ei juuri häirinnyt ja oli jopa hyödyllinen, koska se vaikutti kielen nopeaan kehitykseen, niin 1980-luvulla, jolloin Teollisen kehityksen tarve Lispissä, toteutusten runsaus tuli jarruksi, koska se johti massiiviseen kehityksen päällekkäisyyteen ja voimien hajaantumiseen tukemaan monia Lisp-järjestelmiä.
Lispin standardointia on yritetty lähes sen perustamisesta lähtien (ensimmäinen standardisointiehdotus on peräisin vuodelta 1960), mutta erimielisyyksien ja kiinnostuneiden kehitysryhmien tarpeiden merkittävien erojen vuoksi yhtäkään ehdotuksista ei hyväksytty. 1970-luvun jälkipuoliskolla Yhdysvaltain puolustusministeriö teki hienoa työtä sotilasohjelmistokehityksen tilanteen analysoinnissa, minkä jälkeen se järjesti kilpailun kehittääkseen uuden korkean tason kielen sulautetuille järjestelmille, josta tuli Ada-kieli . Adaa ei kuitenkaan alun perin ollut tarkoitettu tekoälyn ja hahmojen käsittelyyn, minkä seurauksena Yhdysvaltain armeija joutui sallimaan sopivamman kielen käytön tällaisiin tarkoituksiin. Siksi Yhdysvaltain puolustusministeriö tarjosi organisatorista ja taloudellista tukea Lisp-kielen teollisen standardin muodostamiseen, jonka se otti lisätyökaluksi sotilassovellusten ohjelmistojen kehittämiseen.
Alkuperäinen standardiluonnos sai alkunsa Carnegie Mellonin yliopistossa sisäisen Spice Lisp -projektin pohjalta, jonka tarkoituksena oli myös alun perin kehittää työasemalle Lisp-järjestelmä. Suunniteltu standardi sai alusta alkaen nimen "Common Lisp" ("Common Lisp"), joka korostaa kehitystavoitetta - saada yksi peruskieli, jonka pohjalta olisi mahdollista luoda ohjelmistoyhteensopivia järjestelmiä. Noin 80 asiantuntijaa Yhdysvaltain yliopistoista, laboratorioista ja yrityksistä osallistui standardin kehittämiseen ja muokkaamiseen. Kehitysprosessi tapahtui ensimmäistä kertaa etänä, ARPANET -tietokoneverkon kautta , jonka kautta välitettiin yli 3000 viestiä. Standardin kehitysprosessi päättyi vuonna 1984. Hänen tuloksensa kirjattiin Guy Steelen Common Lisp: the Language -julkaisun ensimmäiseen painokseen.
Common Lispin tulo hidasti kielen uusien murteiden luomista. "Vanhat" murteet olivat edelleen olemassa, mutta kun niiden käyttöympäristöt katosivat käytöstä, niin myös vastaavat Lisp-järjestelmät. Suurin osa niistä lakkasi olemasta vuosina 1985-1995. Common Lispissä tehtiin jo uutta kehitystä. Seuraavina vuosina ilmestyi kuitenkin useita uusia Lisp-murteita, joista suurin osa seurasi yksinkertaistamista ja suuntautui mikrotietokoneisiin.
ISLISPISLISP on Lisp-spesifikaatio, joka kehitettiin 1990-luvulla ja jonka ISO julkaisi vuonna 1997 [8] . Eritelmä päivitettiin vuonna 2007 [9] . ISLISP on yritys standardoida Lispin ydin yhdistämällä olemassa olevia ja kehittäviä kaupallisia Lisp-murteita sen perustamishetkellä. Murre on monella tapaa samanlainen kuin Common Lisp (leksinen laajuus, erilliset nimiavaruudet funktioille ja muuttujille, melko tehokas tietotyyppijärjestelmä, tuki monimutkaisille tyypeille, makrojärjestelmä, objektijärjestelmä), mutta laajuudeltaan pienempi. Vuodelle 2018 ISLISP:stä on noin tusina suurta toteutusta, jotka on julkaistu pääasiassa omistetuilla lisensseillä.
openlispChristian Julienin vuonna 1988 luoma murre. Alun perin MLisp-niminen se nimettiin uudelleen OpenLispiksi vuonna 1993. Nimi symboloi avoimien standardien käyttöä, mutta sillä ei ole mitään tekemistä Open Source Initiativen tai vapaan ohjelmiston kanssa: järjestelmää jaetaan omistusoikeuden alaisena.
Täyttää täysin ISLISP-spesifikaation , lisäksi toteuttaa useita tästä standardista puuttuvia ominaisuuksia. Interaktiivinen kehitys ( REPL ) on mahdollista Emacs - ympäristössä . Järjestelmässä on tulkin lisäksi kääntäjä, joka muuntaa lähdekoodin LAP:ksi (Lisp Asssembly Program, assembly-tyyppinen matalan tason koodi Lisp listojen muodossa) sekä koodigeneraattori, joka kääntää LAP-ohjelman lähdekoodiksi. C -kielellä . Paljon huomiota kiinnitetään vuorovaikutukseen C/C++:n ja Java-koodin kanssa, tuki ohjelmistojärjestelmiin upottamiseen sulautetuksi kielen tulkiksi. Järjestelmää kehitetään ja tuetaan edelleen, useimmille saatavilla oleville käyttöjärjestelmille ja laitteistoalustoille on olemassa versioita.
Pico LispPicoLisp on ilmainen Lispin toteutus, joka on suunniteltu käytettäväksi Linuxissa ja muissa POSIX -järjestelmissä . Projekti ilmestyi 1980-luvun lopulla, ja sen tavoitteena oli luoda minimalistinen mutta käytännöllinen Lisp-järjestelmä henkilökohtaisiin tietokoneisiin.
Kielen puolelta PicoLisp on kirjainkoolla huomioitava, tukee UTF-8:aa ja on erittäin yksinkertainen. Ydin tukee vain kolmea tietotyyppiä: numeroita, merkkijonoja ja luetteloita. Parametrien laskettavuuden ohjaamiseen on otettu käyttöön syntaktisia keinoja, lainauslomaketta on laajennettu määrittelemättömään määrään parametreja. Tämä ratkaisu eliminoi erityisen makrojen syntaksin ja lambda-lausekkeen tarpeen. Rakenteita ja taulukoita ei tueta, on taloudellisesti toteutettu, mutta tehokas objektialijärjestelmä. Toisin kuin Common Lisp, kieli käyttää dynaamista parametrien sidontaa.
PicoLisp-ympäristössä ei ole kääntäjää (tämä on perustavanlaatuinen päätös, jonka vuoksi kieleen tehtiin monia yksinkertaistuksia), mutta se sisältää sisäänrakennetun sovelluspalvelimen ja tallennusalijärjestelmän [10] . Toteutettu suora kutsu ulkoisille C-kielellä kirjoitetuille funktioille sekä vuorovaikutus Java-koodin kanssa. Murteen kehitys jatkuu, ohjelmointiympäristöstä julkaistaan säännöllisesti uusia versioita useille alustoille.
EuLisp
Murre, jota on kehittänyt vuodesta 1985 lähtien eurooppalaisten Lisp-kehittäjien ja käyttäjien akateemista ja teollisuudesta koostuva yhteisö. Sitä voidaan pitää eräänlaisena "eurooppalaisena vastauksena yhteiselle lispille" - vaihtoehtoisena yrityksenä luoda yksi Lispin murre, joka soveltuu monenlaisiin tehtäviin. Projektin tavoitteena oli luoda tehokas, kompakti ja rasittamaton "Lisp past" -kieli. Yksi tämän projektin kehittämisen prioriteeteista oli olio-ominaisuuksien lisääminen Lispiin.
Murre tukee moduulien määrittelyä leksikaalisella laajuudella, sulkuja dynaamisilla sidoksilla, yksittäinen nimiavaruus muuttujille ja funktioille, kuten Schemissä, sisäänrakennettu tuki samanaikaisuudelle, objektijärjestelmä, jossa on yksi ja useampi perintö. Projektin ominaisuus on kielen jakaminen kahteen tasoon, Level-0 ja Level-1, jotkut ominaisuudet ovat käytettävissä vain tasolla 1, esimerkiksi moniperintö ja meta-objektit.
Viimeisin virallinen spesifikaatio (versio .99) julkaistiin vuonna 1993 ja sen epävirallinen versio (versio .991) vuonna 2010. Ensimmäinen tulkki julkaistiin vuonna 1990, 1990-2000-luvuilla luotiin useita toteutuksia, joiden kehitys loppui vuoteen 2011 mennessä.
newLispLutz Müllerin vuonna 1991 kehittämä murre käytettäväksi komentosarjakielenä Sun-työasemissa, joissa on SunOS ja FreeBSD. Tällä hetkellä saatavilla 32- ja 64-bittisillä Intel-alustoilla FreeBSD:ssä, Linuxissa, Windowsissa ja Macissa. Poikkeaa yksinkertaisuudesta, pienestä tilavuudesta, muuttujien dynaamisesta laajuudesta, on useita ominaisuuksia syntaksissa. Tukee FOOP-objektijärjestelmää, prosessien välisiä viestintätyökaluja ja paljon muuta. Ympäristö sisältää tulkin, koodieditorilla varustetun mini-IDE:n ja pääteemulaattorin vuorovaikutteista kehitystä varten, kirjastoja web-kehitykseen ja verkottumista TCP- ja UDP-protokollien kautta.
RacketPLT Inc:n kehittämä vuodesta 1994. murre, jonka alkuperäinen nimi oli PLT Scheme. Se on Schemen murteen jälkeläinen, mutta laajentaa sitä merkittävästi. Yksi Racketin luomisen tavoitteista oli tarjota alusta verkkoaluekohtaisten kielten kehittämiselle ja käyttöönotolle. Sen ominaispiirre on erittäin tehokas makrojärjestelmä, jonka avulla voit luoda uusia syntaktisia rakenteita ja jopa kieliä. Samalla moduulijärjestelmä varmistaa eri murteilla kirjoitettujen elementtien käytön yhdessä ohjelmassa eri semantiikkalla.
Toteutus sisältää kääntäjän, ajonaikaisen järjestelmän, JIT-kääntäjän, integroidun kehitysympäristön työkaluineen, kirjastoja. DrRacket IDE, joka on kirjoitettu itse Racketissä, sisältää profilointi-, virheenkorjaus- ja yksikkötestausjärjestelmän. Saatavilla on kirjastoja, jotka tukevat järjestelmä- ja verkkoohjelmointia, web-kehitystä, yksi käyttöliittymä käyttöjärjestelmään, käyttöliittymä ulkoisten toimintojen kutsumiseen, useita säännöllisten lausekkeiden muunnelmia, jäsennys- ja jäsentingeneraattoreita, logiikkaohjelmointityökaluja ja edistynyt graafinen käyttöliittymä. Alusta on toteutettu Windowsille, MacOS:lle, Linuxille ja muille UNIX-versioille. Sitä jaetaan ilmaisena ja avoimen lähdekoodin ohjelmistona GNU Lesser General Public License (LGPL) -lisenssillä. Yhteisön luomille paketeille ja laajennuksille ylläpidetään keskitettyä arkistoa.
Sitä käytetään tutkimuksessa (pääasiassa foorumina kielten ja ohjelmointityökalujen kehittämiseen), koulutus-, komentosarja- , teollisuuskielenä (erityisesti videopelien kehittämiseen). Opetusohjelmassa opetusohjelmassa käytetään Bootstrapia käsitteessä "oppiminen koodaamalla pelejä".
ArcArc on Paul Grahamin luoma murre . Tekijän ilmoittaman projektin tavoitteena on luoda yksinkertainen, taloudellisesti määriteltyjen kokonaisuuksien minimaaliseen joukkoon rakennettu Lisp-järjestelmä, jossa on joukko käytännöllisesti katsoen hyödyllisiä kirjastoja, joka keskittyy ammattikäyttöön ja mahdollistaa tehokkaat "Lisp-hakkerit" (erilaisia laskennallisia temppuja). Lispin ominaisuuksien perusteella). Kirjoittaja periaatteessa kieltäytyi tukemasta joitain teknologioita Arcissa, erityisesti OOP , koska hän katsoi, että niitä tarvitaan vain kehitettäessä suurissa organisaatioissa eivätkä sinänsä anna todellista hyödyllistä vaikutusta. Kehityksestä ilmoitettiin vuonna 2001, ensimmäinen julkinen versio ilmestyi vuonna 2008. Kielen ensimmäinen toteutus kirjoitettiin Racket-ympäristössä. Vuodesta 2009 lähtien alkuperäisen järjestelmän kehittäminen on käytännössä lopetettu, ja nyt Arcin kehitys jatkuu useissa haarukoissa .
Viime vuosikymmeninä kielet, jotka käyttävät automaattista muistinhallintaa, kääntämistä välikoodiksi ja sen suorittamista virtuaalikoneessa, kuten Java, Python, C# ja muut, ovat yleistyneet. Lispin murteita on myös luotu useita, jotka on suunnattu suoritukseen muiden kielten dynaamisissa ympäristöissä. Nämä murteet pystyvät työskentelemään suoraan vastaavan kieliympäristön kirjastojen kanssa ja vuorovaikutuksessa muiden samassa ympäristössä toimivien ohjelmien kanssa. Heidän keskuudessaan:
Pohjimmiltaan standardin ideologisiin perusteisiin vaikuttivat MACLisp ja sen murteet, suuri määrä ominaisuuksia lainattiin InterLISP:stä ja uusista järjestelmistä, kuten Zetalisp ja NIL.
Common Lisp on kieli, jossa on staattinen muuttujasidonta, perinteinen funktioiden esitys (funktiot eivät ole "täyskansalaisia"), tukee makroja, funktioita, leksikaalisia sulkemisia. Eli kielen toiminnallisen osan näkökulmasta se sisältää koko joukon syntaktisia keinoja, jotka Lispissä on kehittyneet viimeisen neljännesvuosisadan aikana ja jotka ovat riittävät mihin tahansa toiminnallisen ohjelmoinnin ja kielen laajennuksen soveltamiseen missä tahansa. haluttu suunta. Common Lispin järjestelmätoiminnot säilyttävät perinteiset nimensä, mutta monilla niistä on synonyymejä kuvaavampien nimien kanssa, esimerkiksi funktioilla CAR(luettelon pään saaminen) ja CDR(luettelon hännän saaminen) on synonyymejä FIRST("first" ) ja REST("jäännös") .
Koska tavoitteena oli kehittää mahdollisimman laajalle käyttöalueelle sopiva järjestelmä, spesifikaatiota laajennetaan merkittävästi funktioilla, syntaktisilla keinoilla ja mekanismeilla, jotka eivät ole tyypillisiä alkuperäiselle Lispille. Joten esimerkiksi lähes kaikki imperatiivisissa kielissä olemassa olevat syntaktiset rakenteet, mukaan lukien useat silmukat, on lisätty kieleen. CLOS (Common Lisp Object System) -oliojärjestelmää ei alun perin sisällytetty standardiin, mutta siitä tuli myöhemmin osa sitä . Common Lisp soveltuu sekä funktionaalisten että ohjelmointityylisten ohjelmien kirjoittamiseen, ohjelmointia on mahdollista yleistää (vakiomakroja käyttäen), tuotantoohjelmointia, on työkaluja logiikan organisointiin, olioohjelmointiin ja dataohjautuvaan ohjelmointiin. Erittely ei sisällä yksityiskohtaista kuvausta ohjelmointiympäristöstä, vaan määritellään vain yleisimmillä termeillä sen koostumus ja elementtien vuorovaikutusperiaatteet.
Uuden standardin kriitikot huomauttivat sen paisumisesta ja käytännön vaatimusten liiallisesta korostamisesta, mikä johti Lispin "toiminnallisen puhtauden" rikkomiseen ja Lisp-järjestelmän koon kasvuun. Siitä huolimatta Yhdysvaltain puolustusministeriön painostuksesta ja osittain sen taloudellisella tuella Common Lisp -toteutukset luotiin 1980-luvun jälkipuoliskolla lähes kaikille yleisille alustoille.
Vuonna 1984 julkaistuun standardiin tehtiin suuri tarkistus vuonna 1990 :
Vuonna 1995 ANSI standardoi Common Lispin . Standardi toisti käytännössä vuoden 1990 määrittelyn, muutokset ovat vähäisiä ja koostuvat pääasiassa operaattoreiden ja järjestelmämuuttujien lisäämisestä, poistamisesta ja uudelleennimeämisestä sekä järjestelmäkutsujen muutoksista. Voimme huomata, että Common Lispissä esiintyy boolean-tyyppiä (boolean), jonka arvot voivat olla vain NIL ja T.
Esimerkkiohjelma, joka näyttää viestin " Hei, maailma!" »:
( muoto t "Hei, maailma!~%" )Variants of Quine (ohjelma, joka tulostaa lähdekoodinsa) Lispissä:
(( lambda ( x ) ( lista x ( lista lainaus x ))) ( lainaus ( lambda ( x ) ( lista x ( lista lainaus x ))))) (( lambda ( x ) ( lista x ( lista 'lainaus x ))) ' ( lambda ( x ) ( lista x ( lista 'lainaus x ))))Molemmat toimivat useimmissa Lisp-murteissa, mukaan lukien Scheme . Kumpi niistä on tarkempi, riippuu Lisp-järjestelmän toteutuksesta: joissakin, kun näytetään luetteloarvo laskennan eston näyttämiseksi, erityinen operaattori quotenäytetään koko nimenä (ensimmäinen vaihtoehto sopii heille) , toisissa - heittomerkkinä (toinen vaihtoehto). Quine's Common Lisp -versio käyttämällä backquote:
(( lambda ( x ) ` ( , x ',x )) ' ( lambda ( x ) ` ( , x ',x )Iteratiivinen versio funktiosta N:nnen Fibonacci-luvun määrittämiseksi silmukkamakron avulla:
( defun fibonacci ( n ) ( silmukan toisto n : a = 0 sitten b ja b = 1 sitten ( + a b ) lopuksi ( paluu b )N:nnen Fibonacci-lukufunktion rekursiivinen versio:
( defun fibonacci ( n ) ( jos ( > n 1 ) ( + ( fibonacci ( - n 1 )) ( fibonacci ( - n 2 ))) n ))Rekursiivinen funktio mielivaltaisen kokonaisluvun tehon laskemiseen (algoritmi logaritmisella suoritusajalla ja rekursion syvyydellä):
( defun teho ( x n ) ( kond (( miinus n ) ( / 1 ( teho x ( - n )))) (( nolla n ) 1 ) (( parillinen p n )( teho ( * x x ) ( / n 2 ))) ( t ( * x ( teho ( * x x ) ( / ( - n 1 ) 2 ))))))Tässä käytetään systeemipredikaatteja ZEROP - tarkista tasa-arvo nollaan, MINUSP - tarkista negatiivisuus, EVENP - tarkista pariteetti.
1955 | 1960 | 1965 | 1970 | 1975 | 1980 | 1985 | 1990 | 1995 | 2000 | 2005 | 2010 | 2015 | 2018 | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Lisp 1.5 | Lisp 1.5 | ||||||||||||||||||||
Maclisp | Maclisp | ||||||||||||||||||||
Interlisp | Interlisp | ||||||||||||||||||||
ZetaLisp | Lisp Machine Lisp | ||||||||||||||||||||
Kaavio | Kaavio | ||||||||||||||||||||
NOLLA | NOLLA | ||||||||||||||||||||
Yhteinen Lisp | Yhteinen Lisp | ||||||||||||||||||||
LeLisp | Le_Lisp | ||||||||||||||||||||
T | T | ||||||||||||||||||||
Emacs Lisp | Emacs Lisp | ||||||||||||||||||||
AutoLISP | AutoLISP | ||||||||||||||||||||
openlisp | openlisp | ||||||||||||||||||||
Pico Lisp | Pico Lisp | ||||||||||||||||||||
EuLisp | EuLisp | ||||||||||||||||||||
ISLISP | ISLISP | ||||||||||||||||||||
uusiLISP | uusiLISP | ||||||||||||||||||||
maila | maila | ||||||||||||||||||||
Vilpittömyys | GNU Guile | ||||||||||||||||||||
Visuaalinen LISP | Visuaalinen LISP | ||||||||||||||||||||
Clojure | Clojure | ||||||||||||||||||||
Arc | Arc | ||||||||||||||||||||
LFE | LFE | ||||||||||||||||||||
Hy | Hy |
Lisp-kielen laajuus on monipuolinen: tiede ja teollisuus, koulutus ja lääketiede, ihmisen genomin dekoodauksesta lentokonesuunnittelujärjestelmään. Lisp-kielen ensimmäiset sovellusalueet liittyivät symboliseen tiedonkäsittelyyn ja päätöksentekoprosesseihin. Nykyään Common Lispin suosituin murre on universaali ohjelmointikieli. Sitä käytetään laajasti erilaisissa projekteissa: Internet-palvelimissa ja -palveluissa, sovelluspalvelimissa ja -asiakkaissa, jotka ovat vuorovaikutuksessa relaatio- ja objektitietokantojen kanssa, tieteellisissä laskelmissa ja peliohjelmissa.
Lispin erikoismurteita on suunniteltu tiettyihin sovelluksiin, esimerkiksi Game Oriented Assembly Lisp (GOAL) luotiin erittäin dynaamisten kolmiulotteisten pelien kirjoittamiseen, siihen on kirjoitettu koko Jak- ja Daxter -pelisarja .
Yksi Lispin käyttötavoista on sen käyttö komentosarjakielenä , joka automatisoi työn useissa sovellusohjelmissa, mukaan lukien:
Lispin tapauksessa on vaikea vetää selkeää rajaa murteen ja jälkeläiskielen välille, koska Lispin eri murteet, jotka on luotu yli puolen vuosisadan olemassaolosta, voivat poiketa toisistaan merkittävästi ja olla yhteensopimattomia. Toisaalta Lispillä on yksinkertaisesti ikänsä vuoksi ollut vaikutusta valtavaan määrään kieliä, ei vain toiminnallisia. Jos tarkastelemme Lispin suoria jälkeläisiä vain kieliä, jotka ovat säilyttäneet ohjelman yleisen rakenteen, mutta ovat syntaktisesti yhteensopimattomia Lispin kanssa, voimme erottaa:
1970-luvun alussa tunnistettiin aikajakojärjestelmän asettamat rajoitukset interaktiivisten ohjelmistojen (johon kuuluvat sekä Lisp-järjestelmät että useimmat Lisp-kielellä kirjoitetut ohjelmat) käyttäjille. Lisäksi Lisp on suhteellisen kallis dynaamiseen tukeen, mukaan lukien ajonaikainen tyyppitarkistus ja säännöllinen roskien kerääminen. Vuonna 1973 syntyi ajatus kehittää henkilökohtainen tietokone (työasema), joka on suunniteltu laitteistosta alkaen erityisesti Lisp-ohjelmien tehokkaimpaan suorittamiseen, mukaan lukien laitteistotuki lambda-laskelmille ja dynaamiselle kirjoittamiselle.
Yhdysvalloissa Lisp-tietokoneiden kehitystyö tapahtui 1970-luvulla Xerox Corporationin Palo Alto Research Centerissä ja MIT :ssä (jälkimmäistä sponsoroi DARPA ). Heidän tuloksensa oli kolmen suuren valmistajan ilmaantuminen 1980-luvun alussa tai puolivälissä: Xerox, Lisp Machine Inc. (LMI) ja Symbolics Inc. Xerox teki Lisp-koneita, jotka tukivat Interlispiä, kaksi viimeistä yritystä tulivat MIT:stä ja keskittyivät Zetalispiin. Hieman myöhemmin Texas Instruments otti haltuunsa Lisp-koneiden tuotannon . Japanissa esiteltiin vuonna 1984 Fujitsun kaupallisen Alpha lisp -koneen ensimmäinen prototyyppi .
Lisp-koneissa oli laitteistoarkkitehtuuri, joka keskittyi luetteloiden käsittelyyn ja toiminnalliseen ohjelmointiin sekä laitteistotuki roskien keräämiseen ja dynaamiseen kirjoittamiseen. Heillä oli integroituja kehitysympäristöjä, jotka sisälsivät tuhansia toimintoja ja kaikki komponentit, jotka tällä hetkellä muodostavat korkean tason kielten IDE :t. Tuettu usean ikkunan graafinen käyttöliittymä , työskentely hiiren ja muiden lisäpaikannustyökalujen kanssa ( ohjauspallo , valokynä ), korkealaatuinen I/O-grafiikka ja ääni. Vaikka Lisp-suuntautuneita, myös muita korkean tason kieliä oli saatavilla Lisp-koneissa ja ne tarjosivat välineet kielten väliseen yhteentoimivuuteen. Lisp tarjosi sekä työn tulkitussa tilassa että ohjelmien kääntämisen objektikoodiksi.
Lisp-koneet olivat aikansa aikana tehokkaimpia tietokoneita henkilökohtaisten työasemien luokassa. Niillä ennustettiin olevan suuri tulevaisuus, mutta 1990-luvulla ne kaikki poistuivat käytöstä, ja valmistajat joko lopettivat toimintansa tai suuntautuivat uudelleen yleiskäyttöisten tietokoneiden tuotantoon. Syynä oli se, että tietokoneiden nopeuden ja muistin pitkän eksponentiaalisen kasvun yhteydessä "kielen alla" olevien laitteiden kehittäminen osoittautui turhaksi - nopeasti kehittyvät yleiskäyttöiset Lisp-kääntäjillä varustetut tietokoneet ohittivat Lisp-koneet. ominaisuudet, jotka erikoistumisestaan johtuen olivat kalliimpia ja menettivät monipuolisuuden.
Neuvostoliitossa Lispin käyttöön ja omien Lisp-järjestelmien luomiseen liittyvä työ aktivoitui vuoden 1968 jälkeen, jolloin joukko amerikkalaisia tutkijoita, joiden joukossa olivat McCarthy ja B. Berkeley[ selventää ] vieraili Neuvostoliitossa. Novosibirskissä Tiedeakatemian Siperian sivuliikkeen tietokonekeskuksessa, jossa McCarthy vietti suurimman osan ajastaan, hän loi perustan Lispin käyttöönotolle BESM-6 :ssa . Moskovassa, Neuvostoliiton tiedeakatemian laskentakeskuksessa, Neuvostoliiton matemaatikot Lavrov ja Silagadze aloittivat Berkeleyn avustuksella työskennellä oman versionsa Lisp-tulkista BESM-6:lle. Myöhemmin Lavrov meni töihin Leningradin valtionyliopistoon ja Silagadze Georgian tiedeakatemian laskentakeskukseen Tbilisissä, missä he jatkoivat työskentelyä Lispin kanssa ja osallistuivat useiden Lisp-järjestelmien luomiseen ES-tietokoneille . [yksitoista]
Lisp-järjestelmä puolalaiselle tietokoneelle Odra 1204 luotiin Leningradissa, BESM-6:lle yhteensopiva Lisp-version englanninkielinen versio ICL 4 -tietokoneelle luotiin Moskovassa, ES-tietokoneen toteutukset ilmestyivät MPEI:ssä ja Farissa. Itäinen tiedekeskus Vladivostokissa. Tiedonsiirto-ongelmien instituutissa (Moskova) 1970-luvun lopulla luotiin EKLISP-lisp-järjestelmä ECLIPS-minitietokoneelle. Neuvostoliitossa länsimaisissa tietokoneissa käytettiin Stanford Lisp ja UT-Lisp (Dubna, IBM 370 ja CDC 6600). Myös ruotsalainen Nordström-järjestelmä (Fortranissa Lisp) oli suosittu.
Vuonna 1975 Tbilisissä pidettiin neljäs kansainvälinen konferenssi tekoälyn ongelmista IJCAI-75, mikä lisäsi kiinnostusta Lispia kohtaan ja levitti sitä yliopistoihin ja tutkimuslaitoksiin. Vuonna 1978 julkaisivat ensimmäisen venäjänkielisen Lisp-oppikirjan Svjatoslav Lavrov ja Givi Silagadze ("Automaattinen tietojenkäsittely. LISP-kieli ja sen toteutus").
1980-luvulla kiinnostus Lispia kohtaan Neuvostoliitossa jatkui, mutta kielestä julkaistiin hyvin vähän kirjallisuutta (vuosikymmenen aikana julkaistiin kaksi kirjaa, molemmat käännettynä: "Functional Programming. Application and Implementation", Henderson, käännetty 1983, ja Hyvösen ja Seppäsen kaksiosainen "The World of Lisp", jonka käännös julkaistiin vuonna 1990).
Neuvostoliiton jälkeisellä Venäjällä Lispin käyttö rajoittuu enimmäkseen akateemiseen tutkimukseen ja yksittäisten harrastajien työhön. Lisäksi Lispiä käytetään edelleen opetustarkoituksiin joissakin venäläisissä yliopistoissa, mutta täälläkin se on viime vuosina ollut selvästi syrjäytynyt: yleiskielenä sitä ei opeteta eikä käytetä, ja nuoremmat opiskelijat haluavat usein käyttää sitä opetuskielinä toiminnallisen ohjelmoinnin opettamiseen. toiminnallisia kieliä, jotka ovat ilmaantuneet viimeisen kahden vuosikymmenen aikana. Siitä huolimatta kiinnostus kieltä kohtaan säilyy, mistä on osoituksena käännettyjen ja alkuperäisten painettujen teosten ilmestyminen Lispissä, joka jatkui 2010–2020-luvuilla [12] .
Lisp | |||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Ominaisuudet |
| ||||||||||||||
Toteutukset |
| ||||||||||||||
Laitteisto |
| ||||||||||||||
Yhteisö |
| ||||||||||||||
|
Ohjelmointikielet | |
---|---|
|