LISP
Dan Tobias (Talk | contribs) |
Dan Tobias (Talk | contribs) |
||
(6 intermediate revisions by 2 users not shown) | |||
Line 4: | Line 4: | ||
|released=1958 | |released=1958 | ||
}} | }} | ||
− | + | '''LISP''' (LISt Processing) is a programming language dating back to 1958; only [[FORTRAN]] is older among programming languages still in use. While it was originally written in all capitals due to its acronymic origins, it's now more typically written as a normal proper name, "Lisp". | |
It's known as "the programming language with all the parentheses" due to its syntax consisting of deeply nested structures, the so-called S-Expressions. (This attribute is shared by [[TRAC programming language]], but LISP is better-known, as well as [[Scheme]], which started as an effort to formalize and standardize LISP and later led to the "Common LISP" variant of LISP.) LISP treats everything as a list which can be manipulated by its operators, including LISP commands themselves, so programs are able to be self-modifying. | It's known as "the programming language with all the parentheses" due to its syntax consisting of deeply nested structures, the so-called S-Expressions. (This attribute is shared by [[TRAC programming language]], but LISP is better-known, as well as [[Scheme]], which started as an effort to formalize and standardize LISP and later led to the "Common LISP" variant of LISP.) LISP treats everything as a list which can be manipulated by its operators, including LISP commands themselves, so programs are able to be self-modifying. | ||
Line 10: | Line 10: | ||
Some of its cryptically-named operators, such as '''car''' (for the first element of a list) and '''cdr''' (for the remainder of the list), derive from the particulars of the register structure of the original computer it was implemented on (where these operators stand for "contents of address register" and "contents of decrement register"). | Some of its cryptically-named operators, such as '''car''' (for the first element of a list) and '''cdr''' (for the remainder of the list), derive from the particulars of the register structure of the original computer it was implemented on (where these operators stand for "contents of address register" and "contents of decrement register"). | ||
− | + | Some modern programming languages, including [[Clojure]], are based on LISP, and represent a paradigm called "functional programming" that is currently popular. | |
− | * [ | + | == Sample files == |
+ | * {{DexvertSamples|text/lisp}} | ||
+ | |||
+ | == References == | ||
+ | * [[Wikipedia:Lisp (programming_language)|Lisp (Wikipedia)]] | ||
* [http://blog.nullspace.io/apple-2-lisp-part-1.html Turning the Apple //e into a lisp machine] | * [http://blog.nullspace.io/apple-2-lisp-part-1.html Turning the Apple //e into a lisp machine] | ||
+ | * [http://www.defmacro.org/ramblings/lisp.html The Nature of Lisp] | ||
+ | * [https://archive.org/details/bitsavers_symbolicssnLispInterfaceManagerCLIMRelease2.0_1638498 Symbolics Common Lisp Interface Manager manual] | ||
+ | * [http://www.cs.cmu.edu/~dst/LispBook/ Common Lisp: A Gentle Introduction to Symbolic Computation, by David S. Touretzky (free online book)] |
Latest revision as of 17:11, 3 February 2024
LISP (LISt Processing) is a programming language dating back to 1958; only FORTRAN is older among programming languages still in use. While it was originally written in all capitals due to its acronymic origins, it's now more typically written as a normal proper name, "Lisp".
It's known as "the programming language with all the parentheses" due to its syntax consisting of deeply nested structures, the so-called S-Expressions. (This attribute is shared by TRAC programming language, but LISP is better-known, as well as Scheme, which started as an effort to formalize and standardize LISP and later led to the "Common LISP" variant of LISP.) LISP treats everything as a list which can be manipulated by its operators, including LISP commands themselves, so programs are able to be self-modifying.
Some of its cryptically-named operators, such as car (for the first element of a list) and cdr (for the remainder of the list), derive from the particulars of the register structure of the original computer it was implemented on (where these operators stand for "contents of address register" and "contents of decrement register").
Some modern programming languages, including Clojure, are based on LISP, and represent a paradigm called "functional programming" that is currently popular.