Lisp (istorijski, LISP) je familija programskih jezika sa dugom istorijom. Lisp je drugi najstariji viši programski jezik koji se i danas veoma koristi. Jedino je Fortran stariji (godinu dana).[1][2] Danas postoji veliki broj dijalekata Lisp-a, a najpoznatiji među njima su Common Lisp i Scheme.
Čisti Lisp je primer funkcionalnog programskog jezika. U funkcionalnom programiranju, funkcije se primenjuju na argumente i vrednosti. Vraćene vrednosti se koriste kao argumenti za druge funkcije. Funkcionalno programiranje je suprotno proceduralnom programiranju, gde se koriste naredbe koje menjaju okruženje programa na neki način, kao što je pripisivanje vrednosti promenljivim. U funkcionalnom programiranju, te promene okruženja se minimizuju korišćenjem vrednosti koje vraća pozvana funkcija kao direktan ulaz u drugu funkciju, bez upotrebe pripisivanja naredbi.
Ime LISP je nastalo od "LISt Processor". Povezane liste su jedan od glavnih tipova podataka.
Istorijat
Džon Makarti (gore) i Stiv Rasel (dole)
Lisp je projektovao Džon Makarti 1958. godine. Lisp je prvi put implementiran od strane Stiva Rasela na IBM 704 računaru. Rasel je pročitao Makartijev rad i zaključio da izračunavanje u Lispu može da se implementira na mašinskom jeziku. Rezultat toga je interpretator koji je mogao da pokreće Lisp programe, ali i da računa vrednosti Lisp izraza.
Prvi kompletan Lisp kompajler, napisan u Lisp-u, implementirali su Tim Hart i Majk Levin 1962. godine.
Tokom 1980-ih i 1990-ih radilo se na ujedinjavanju novih dijalekata Lisp-a. Tako je nastao programski jezik Common Lisp. Prvi standard za Common Lisp, "ANSI X3.226-1994 Information Technology Programming Language Common Lisp.", objavio je ANSI 1994. godine.
Edsger Dajkstra je na dodeli Tjuringove nagrade 1972. godine rekao:
"Sa nekoliko osnovnih principa svog zasnivanja, on (LISP) je pokazao izuzetnu stabilnost. Osim toga, LISP je bio nosač značajnog broja najsavremenijih kompjuterskih aplikacija. LISP je u šali opisan kao "najinteligentniji način da se zloupotrebi računar". Mislim da je takav opis veliki kompliment, jer prenosi pun ukus slobode: on je pomogao veliki broj naših najtalentovanijih kolega u razmišljanju o ranije nemogućim stvarima."[3]
Sintaksa i semantika
Simbolički izrazi (S-izrazi)
Lisp je jezik koji se oslanja na izraze. Kada se izraz evaluira, on vraća vrednost, koja se može iskoristiti u drugim izrazima.
Svaka vrednost može biti bilo koji tip podataka.
U Lisp-u se navode dva tipa sintakse: S-izrazi (simbolički izrazi), koji oslikavaju unutrašnju reprezentaciju i koda i podataka, i M-izrazi (meta izrazi), koji izražavaju funkcije S-izraza. Skoro svi Lisp jezici danas koriste S-izraze za kod i podatke.
Ono što je Lisp odmah odvojilo od drugih porodica jezika, jeste upotreba zagrada. Sintaksa koja koristi S-izraze je zaslužna za lakše korišćenje programskog jezika Lisp. Međutim, sintaksa Lisp-a nije ograničena na tradicionalnu notaciju pomoću zagrada. Može se proširiti i uključiti i druge notacije.
Oslanjanje na izraze daje veliku fleksibilnost jeziku. Lisp funkcije su napisane kao liste, stoga se one mogu obrađivati kao bilo koji drugi podaci. Ovo omogućava lako pisanje programa koji koriste druge programe (metaprogramiranje). Mnogi Lisp dijalekti koriste ovu odliku, koristeći makro sisteme, što omogućava proširenje jezika gotovo bez ograničenja.
Liste
Lista se zapisuje tako što se između zagrada navedu elementi liste, odvojeni razmacima. Na primer, (1 2 foo) je lista čiji elementi su tri atoma 1, 2 i foo; 1 i 2 jesu celi brojevi, dok je foo specijalan tip podataka u Lisp-u, simbol.
Prazna lista () se takodje moze predstaviti kao specijalni atom nil. Ovo je jedini entitet u Lisp-u
koji je ujedno i lista i atom.
Izrazi se zapisuju kao liste, koristeći prefiksnu notaciju. Na primer, ako navedemo
(ABCD)
A predstavlja ime funkcije (ime makroa, lambda izraz ili ime specijalnog operatora), dok su B, C i D argumenti.
Liste mogu biti ugnježdene. Na primer:
(A(BC)D(E(FG)))
Operatori
Aritmetički operatori se tretiraju na sledeći način:
(+1234)
Ovaj izraz ima vrednost 10. Ekvivalentan izraz u infiksnoj notaciji jeste "1 + 2 + 3 + 4". Aritmetički operatori u Lisp-u su n-arne funkcije, tako da mogu imati bilo koliko argumenata. Operator inkrementiranja u C-u "++" ovde je implementiran kao:
(incfx)
što je ekvivalentno sa (setq x (+ x 1)), koje vraća novu vrednost od x.
Specijalni operatori, koji se ponekad nazivaju i specijalnim formama obezbeđuju kontrolne strukture. Na primer, specijalni operator if ima tri argumenta. Ako prvi argument nije nil, određuje se vrednost drugog argumenta, a ako jeste, onda se određuje vrednost trećeg argumenta. Na primer,
(ifnil(list12"foo")(list34"bar"))
biće (3 4 "bar").
Lambda izrazi i definicija funkcije
lambda je jedan specijalni operator koji se koristi za vezivanje promenljivih vrednostima koje su evaluirane unutar izraza. Takođe se koristi za pravljenje funkcija. Argumenti operatora lambda jesu liste argumenata, a vrednost koju vraća je vrednost poslednjeg evaluiranog izraza. Na primer, izraz
(lambda(arg)(+arg1))
predstavlja funkciju koja uzima jedan argument, vezuje ga za arg i vraća broj za jedan veći od argumenta. Lambda izrazi se pozivaju na isti način kao i funkcije. Na primer:
((lambda(arg)(+arg1))5)
vraća vrednost 6.
Atomi
U prvobitnom LISP-u su postojale dva osnovna tipa podataka: atomi i liste. Lista je konačan niz elemenata gde je svaki element za sebe lista ili atom, a atom je ili broj ili simbol, koji ima formu identifikatora. Na primer,
(FOO(BAR1)2)
sadrži tri elementa: simbol FOO, listu (BAR 1) i broj 2.
Suštinska razlika između atoma i listi jeste ta da su atomi nepromenljivi i jedinstveni, dok je svaka lista poseban objekat koja može da se menja nezavisno od drugih listi.
Liste i elementi liste
Lisp lista je jednostruko povezana lista. Svaka ćelija liste se naziva cons(od CONStruct cell ili CONStruct list) i sastoji se od dva pokazivača, koji se nazivaju car(Contents of Address part of Register) i cdr(Contents of Decrement part of Register). Oni, redom, odgovaraju elementu i pokazivaču u povezanoj listi.
Ako uzmemo da nam dati cons bude glava povezane liste, onda njegov car pokazivač pokazuje na prvi element liste, a cdr pokazuje na ostatak liste. Iz tog razloga car i cdr funkcije imaju i naziv prvi i ostatak kada se govori o elementima koji su deo povezane liste.
Veoma se često koriste kod rekurzivno napisanih funkcija koje u svom prvom prolazu obrađuju samo jedan element, a zatim se sa cdr uzima ostatak liste koji se rekurzivno prosleđuje istoj funkciji da isti posao obavi i za sve druge elemente
Zbog toga što su cons i liste univerzalne u Lisp sistemima, česta je zabluda da su oni jedine strukture podataka u Lisp-u. U stvari, postoje i druge strukture podataka, poput vektora (nizova), heš tabeli...
Cons može da se napiše u dotted-pair notaciji kao (a . b), gde a predstavlja car, a b predstavlja cdr.
Funkcije za rad sa listama
Lisp ima mnoge ugrađene funkcije za pristup i kontrolu listi. Lista se može kreirati direktno pomoću funkcije list, koja uzima bilo koji broj argumenata i vraća listu tih argumenata.
(list12'a3);Output: (1 2 a 3)
(list1'(23)4);Output: (1 (2 3) 4)
Funkcija cons se može iskoristiti za dodavanje na početak liste.
(cons1'(23));Output: (1 2 3)
(cons'(12)'(34));Output: ((1 2) 3 4)
Funkcija reverse obrće listu.
(reverse'(abcd));Output: (d c b a)
Funkcija length računa dužinu liste.
(length‘(a(bc)d));Output: 3
(length‘(abcd));Output: 4
Funkcija append spaja dve ili više listi.
(append'(12)'(34));Output: (1 2 3 4)
(append'(123)'()'(a)'(56));Output: (1 2 3 a 5 6)
Postoji još mnogo funkcija ovog tipa, koje proveravaju da li je određen argument prazna lista, da li je taj argument uopšte lista i slične. ( null , listp…)
Deljene strukture
Lisp liste, koje su jednostruko povezane, mogu da podele strukturu međusobno. To jest, dve liste mogu da imaju isti rep ili krajnji niz cons ćelija. Na primer, nakon izvršenja sledećeg Common Lisp koda
(setffoo(list'a'b'c))(setfbar(cons'x(cdrfoo)))
liste foo i bar su (a b c) i (x b c), redom. Međutim, rep (b c) je ista struktura u obe liste. Nije kopija već cons ćelije koje pokazuju na b i c su na istoj memorijskoj lokaciji.
Međutim, ukoliko se, u nekom trenutku, zameni b ili c u foo, zameniće se i u bar, što je neočekivani rezultat. Ovo može biti izvor grešaka, pa su funkcije koje menjaju svoje argumente označene kao destruktivne, upravo iz ovog razloga.
Samoevaluirajući oblici i operator navođenja quote
Lisp određuje vrednost izraza koji korisnik unese. Simboli i liste određuju vrednost nekog drugog izraza, uglavnom jednostavnijeg. Na primer, simbol određuje vrednost promenljive koju imenuje; (+ 2 3) vraća 5. Kako god, većina oblika vraća vrednost njih samih: ako se unese 5 u Lisp-u, on vraća 5.
Svaki izraz može biti obeležen kako bi se sprečila njegova evaluacija (ako je potreban za simbole i liste). To je uloga specijalnog operatora quote ili skraćeno' (jednostruki navodnik). Na primer, ako se ukuca foo vratiće se vrednost odgovarajuće promenljive (ili greška ako ta promenljiva ne postoji). Ako je potrebno referisati na neki literalni simbol, kuca se (quote foo) ili 'foo.
Samoevaluirajući oblici i forme navođenja su u Lisp-u ekvialentni sa literalima. To omogućava modifikaciju (promenljivih) literala u programskom kodu. Na primer, ako funcija vraća neku formu navođenja i kod koji poziva funkciju modifikuje formu, to može promeniti ponašanje funkcije u narednim iteracijama.
(defunshould-be-constant()'(onetwothree))(let((stuff(should-be-constant)))(setf(thirdstuff)'bizarre)); loše!(should-be-constant); vraća (one two bizarre)
Prostor imena
Lisp je podeljen oko upotrebe dinamičke i statičke (odnosno leksičke) upotrebe prostora imena. Clojure, Common Lisp i Scheme podrazumevano koriste statičko definisanje polja promenljive, dok Newlisp, Picolisp i ugrađeni jezici u Emacs-u i AutoCAD-u koriste dinamičko.
Spisak struktura programskog koda; makroi i kompajleri
Osnovna razlika između Lisp-a i ostalih jezika je u tome što je tekstualna reprezentacija programa prilično čitljiv opis same unutrašnje strukture podataka (povezanih listi, simbola, brojeva, karaktera, itd.) kao što je u osnovi Lisp sistema.
Zahvaljujući tome, Lisp implementira veoma jak sistem makroa. Kao i u ostalim makro jezicima kao što je C, makro vraća kod koji može biti kompajliran. Za razliku od C-ovih makroa, u Lisp-u su makroi funkcije i u njima je moć Lisp-a.
Pošto kod u Lisp-u ima istu strukturu kao liste, makroi mogu biti izraženi pomoću bilo koje funkcije za rad sa listama. Ukratko, sve što može Lisp sa strukturom podataka, Lisp makroi mogu sa kodom.
U jednostavnoj implementaciji Lisp-a, ova struktura u vidu liste je direktno interpretirana da pokrene program; funkcija je doslovno deo strukture liste koja prevedena od strane interpretatora pri izvršavanju. Većina Lisp sistema sadrži i kompajler. On prevodi strukturu liste na mašinski jezik ili bajtkod za izvršavanje. Ovaj kod može biti pokrenut jednako brzo kao i u C-u, na primer.
Makroi nude interesantne opcije.
Neke implementacije Lisp-a imaju mehanizam eval-when koji omogućava kodu da bude prisutan za vreme kompilacije (kad zatreba makrou) ali nije prisutan u emitujućem modulu.[4]
Evaluacija i read–eval–print petlja
Lisp jezici su najčešće korišćeni sa interaktivnom komandnom linijom, koja se može kombinovati sa IDE-om. Lisp čita unete izraze, evaluira ih i štampa rezultat. Zbog ovoga, Lisp komandna linija se naziva "read–eval–print petlja", odnosno REPL.
read funkcija prihvata tekstualni S-izraz kao ulaz i parsira ga u unutrašnju strukturu podataka.
Na primer, ako se ukuca tekst (+ 1 2) u promptu, read ga prevodi u povezanu listu sa tri elementa: simbol +, broj 1 i broj 2. Ova lista je takođe validan deo Lisp koda i može se evaluirati.
Treba napomenuti da se foo čita kao pojedinačni simbol.
123 će se pročitati kao broj sto dvadeset tri, a "123" će se pročitati kao string "123".
eval funkcija evaluira podatke, vraća nula ili više Lisp podataka kao rezultat. Evaluacija ne mora značiti isto što i interpretacija; pojedini Lisp sistemi kompajliraju svaki izraz u mašinski kod koji se može izvršiti direktno od strane CPU. Svakako je jednostavno objasniti evaluaciju kao interpretiranje: Da bi se evaluirala lista čiji car imenuje funkciju,
eval prvo evaluira svaki od argumenata koji je prosleđen njenom cdr-u, potom primenjuje funkciju na argumente. U ovom slučaju, funkcija je sabiranje i primenjujući je na argumente liste (1 2) daje rezultat 3. To je, zapravo, rezultat evaluacije.
Simbol foo evaluira vrednost simbola foo. Podatak kao što je string "123" evaluira isti string. Lista (quote(1 2 3)) evaluira (1 2 3).
Posao funkcije print je da prikaže izlaz korisniku. Za jednostavan rezultat kao što je 3 to je trivijalno. Izraz koji evaluira deo strukture liste bi zahtevao da print prođe kroz listu i štampa je kao S-izraz.
Za implementaciju Lisp REPL-a, neophodno je implementirati navedene tri funkcije i funkciju "beskonačna petlja". Naravno da implementacija funkcije eval nije jednostavna, posebno jer je potrebno implementirali sve specijalne operatore kao što su if ili lambda.
Kada je ovo završeno, REPL nije ništa drugo do jedna linija koda: (loop (print (eval (read)))).
Lisp REPL omogućava redigovanje ulaza, istoriju ulaza, upravljanje greškama kao i interfejs dibagera.
Lisp je prvobitno imao samo nekoliko struktura, ali veliki broj je dodavan tokom evolucije jezika. (Lisp-ov prvobitni uslovni operator, cond, prethodnik je kasnije if-then-else strukture.
Pojedine Lisp-ove kontrolne strukture su specijalni operatori, ekvivalenti sintaksnim ključnim rečima drugih jezika. Izrazi koji koriste ove operatore imaju isti izgled kao pozivi funkcija, razlika je jedino u tome što argumenti ne moraju biti evaluirani ili u iterativnom slučaju mogu biti evaluirani više od jedanput.
Za razliku od ostalih viših programskih jezika, Lisp dopušta programeru da implementira kontrolne strukture koristeći jezik. Nekoliko kontrolnih strukutura je implementirano kao Lisp makroi, a nekoliko njih mogu biti makro razvijeni od strane programera koji znaju kako to radi.
I Common Lisp i Scheme imaju operatore za nelokalnu kontrolu toka. Razlike u ovim operatorima ujedno čine i razlike između ova dva dijalekta.
Neretko, isti algoritam u Lisp-u može biti iskazan i imperativnim i funkcionalnim stilom. Scheme preferira funkcionalni stil koristeći repnu rekurziju. Kako god, imperativni stil je još uvek moguć. Stil koji preferiraju Common Lisp programeri bliži je programerima koji koriste struktuirane jezike kao što je C, dok je onaj koji preferiraju Scheme programeri bliži čisto funkcionalnim jezicima kao što je Haskell.
Lisp ima široki spektar funkcija višeg reda koje su u relaciji sa itaracijom u naredbama. U mnogim slučajevima gde bi u drugom jeziku bila neophodna petlja (kao for u C-u) u Lisp-u stvar rešava funkcija višeg reda.
Lisp sintaksa je podesna za rekurziju. Matematički problemi kao što je nabrajanje rekurzivno definisanim skupovima jednostavno se izražavaju u ovoj notaciji.
Računanje faktorijela:
(defunfactorial(n)(if(=n0)1(*n(factorial(-n1)))))
Alternativna implementacija, često brža od prethodne ako Lisp sistem ima optimizaciju u vidu repne rekurzije:
^„SICP: Foreword”. Архивирано из оригинала 27. 07. 2001. г. Приступљено 19. 04. 2016. „Lisp is a survivor, having been in use for about a quarter of a century. Among the active programming languages only Fortran has had a longer life.”
دوري الدرجة الأولى الروماني 1925–26 تفاصيل الموسم دوري الدرجة الأولى الروماني النسخة 14 البلد رومانيا التاريخ بداية:20 يونيو 1926 نهاية:1 أغسطس 1926 المنظم اتحاد رومانيا لكرة القدم البطل نادي تشينزول تيميشوارا عدد المشاركين 10 دوري الدرجة الأولى الرومان...
Zozibini TunziZozibini Tunzi di Puteri Indonesia 2020.Lahir18 September 1993 (umur 30) Tsolo, Eastern Cape, Afrika SelatanPendidikanPublic RelationAlmamaterCape Peninsula University of TechnologyTinggi178 cm (5 ft 10 in)Pemenang kontes kecantikanGelar Miss South Africa 2019 Miss Universe 2019 Warna rambutHitamWarna mataCoklatKompetisiutama Miss South Africa 2017(Top 26) Miss South Africa 2019(Pemenang) Miss Universe 2019(Pemenang) Zozibini Tunzi (lahir 18 September 1993) ...
For other uses, see Laborec (disambiguation). River in Ukraine, SlovakiaLaborecLaborec at StrážskeLocationCountryUkraine, SlovakiaPhysical characteristicsSource • locationLaborec Highlands Mouth • locationLatorica • coordinates48°30′14″N 21°54′04″E / 48.504°N 21.901°E / 48.504; 21.901Length126 km (78 mi)Basin size4,523 km2 (1,746 sq mi)Basin featuresProgressionL...
Aquarium in Sydney, Australia Sea Life Sydney AquariumMain entrance33°52′10″S 151°12′07″E / 33.8694°S 151.2019°E / -33.8694; 151.2019Date opened1988; 36 years ago (1988)LocationSydney, New South Wales, AustraliaNo. of animals13,000No. of species700Volume of largest tank2,000,000 litres (440,000 imp gal; 530,000 US gal)Annual visitorsOver 1.2 millionMembershipsZAA,[1] WAZA[2]Major exhibitsDay and Night on...
Artikel ini sebatang kara, artinya tidak ada artikel lain yang memiliki pranala balik ke halaman ini.Bantulah menambah pranala ke artikel ini dari artikel yang berhubungan atau coba peralatan pencari pranala.Tag ini diberikan pada April 2016. Nico VegaAsalLos Angeles, CaliforniaGenreAlternative rockTahun aktif2005–sekarangLabelMySpace Records (2007–2009) Five Seven Music (2012–sekarang)Situs webNicoVega.comAnggotaAja VolkmanRich KoehlerDan EpandJamila WeaverMantan anggotaMike Peña Nico...
This article includes a list of references, related reading, or external links, but its sources remain unclear because it lacks inline citations. Please help improve this article by introducing more precise citations. (November 2023) (Learn how and when to remove this message) Football clubWarnsdorfer FKClub logoFull nameWarnsdorfer Fußball KlubFounded10 January 1931Dissolved1940GroundPlatz am Hauptbahnhof, Varnsdorf Warnsdorfer Fußball Klub, commonly known as Warnsdorfer FK, was an associa...
يفتقر محتوى هذه المقالة إلى الاستشهاد بمصادر. فضلاً، ساهم في تطوير هذه المقالة من خلال إضافة مصادر موثوق بها. أي معلومات غير موثقة يمكن التشكيك بها وإزالتها. (نوفمبر 2019) كأس النرويج 1930 تفاصيل الموسم كأس النرويج النسخة 29 البلد النرويج المنظم اتحاد النرويج لكرة القد...
Political organization in Bessarabia that proclaimed the Moldavian Democratic Republic For other uses, see Sfatul Țării (disambiguation). This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these template messages) This article's tone or style may not reflect the encyclopedic tone used on Wikipedia. See Wikipedia's guide to writing better articles for suggestions. (December 2009) (Learn how and when to remove this ...
American baseball player (born 1989) Baseball player Brett OberholtzerOberholtzer with the Phillies in 2016PitcherBorn: (1989-07-01) July 1, 1989 (age 34)Christiana, Delaware, U.S.Batted: LeftThrew: LeftMLB debutApril 21, 2013, for the Houston AstrosLast MLB appearanceOctober 1, 2016, for the Los Angeles AngelsMLB statisticsWin–loss record14–23Earned run average4.36Strikeouts220 Teams Houston Astros (2013–2015) Philadelphia Phillies (2016) Los Angeles ...
Докладніше: Втрати силових структур внаслідок російського вторгнення в Україну У статті наведено список втрат українських військовослужбовців у російсько-українській війні з січня по червень 2021 року. Зміст 1 Усі списки 2 Список загиблих з 1 січня до 30 червня 2021 року 2.1 �...
Toxic effects of breathing oxygen at high partial pressures Medical conditionOxygen toxicityOther namesOxygen toxicity syndrome, oxygen intoxication, oxygen poisoningIn 1942–43 the UK Government carried out extensive testing for oxygen toxicity in divers. The chamber is pressurised with air to 3.7 bar. The subject in the centre is breathing 100% oxygen from a mask.[1]SpecialtyDiving medicine, hyperbaric medicine, neonatal medicine. Oxygen toxicity is a condition resulting from ...
فايوالشعارمعلومات عامةالبلد اليابان التأسيس 1996 النوع ماركة المقر الرئيسي أزومينو، ناغانو موقع الويب vaio.com المنظومة الاقتصاديةالصناعة حاسوب محمول — هاتف ذكي المنتجات حاسوب محمول أهم الشخصياتالمالك VAIO (en) تعديل - تعديل مصدري - تعديل ويكي بيانات فايو (بالإنجليزية: VAIO) ه�...
Ethnic group Latvian JewsLatvijas ebrejiיהדות לטביהRegions with significant populations Latvia8,094 (2021, including Karaim and Krymchaks)[1]LanguagesHebrew, Russian, Latvian, German (historically), and YiddishReligionJudaismRelated ethnic groupsJews, Ashkenazi Jews, Belarusian Jews, Russian Jews, Lithuanian Jews, Estonian Jews, Polish Jews The location of Latvia (dark green) in Europe Part of a series onJews and Judaism Etymology Who is a Jew? Religion God in Judaism&...
Aircraft consulting company The topic of this article may not meet Wikipedia's notability guidelines for companies and organizations. Please help to demonstrate the notability of the topic by citing reliable secondary sources that are independent of the topic and provide significant coverage of it beyond a mere trivial mention. If notability cannot be shown, the article is likely to be merged, redirected, or deleted.Find sources: Burnham Sterling and Company – news · ne...