Joke Collection Website - Joke collection - The Software Story says that Lisp is a great progress for FORTRAN. What are the advantages of Lisp over FORTRAN?
The Software Story says that Lisp is a great progress for FORTRAN. What are the advantages of Lisp over FORTRAN?
If we put the popular programming languages in this order: Java, Perl, Python, Ruby. You will find that the later the language, the more like Lisp. Python imitates Lisp and even imitates many functions that Lisp hackers think are design errors. As for Ruby, if you go back to 1975, you claim that it is a Lisp dialect, and no one will object. The development of programming language has just caught up with the level of 1958 Lisp language.
Second,
1958, john mccarthy designed the Lisp language. In my opinion, the latest programming language only realized his idea in 1958.
How is that possible? Isn't the development of computer technology changing with each passing day How does the technology of 1958 surpass today's level?
Let me tell you why.
This is because john mccarthy did not intend to design Lisp as a programming language, at least not in our present sense. His original intention was only to make a theoretical calculation and define Turing machine in a more concise way.
So, why isn't the programming language of the 1950s out of date? Simply put, because this language is not technology in essence, but mathematics. Mathematics is not outdated. You should not associate Lisp with the hardware of the 1950s, but compare it with quick sort. This algorithm was put forward by 1960, and it is still the fastest general sorting method.
Third,
Fortran language also appeared in the 1950s, and it has been used ever since. It represents a completely different direction of language design. Lisp unintentionally developed from pure theory to programming language, and Fortran was designed as a programming language from the beginning. However, today we regard Lisp as a high-level language and Fortran as a rather low-level language.
1956, Fortran was called Fortran I when it was first born, which is very different from today's Fortran language. Fortran I is actually an assembly language plus mathematics. In some ways, it is not as powerful as today's assembly language. For example, subroutines are not supported, only branches are supported.
Lisp and Fortran represent two major directions of programming language development. The former is based on mathematics and the latter is based on hardware architecture. Since then, the two directions have become closer and closer. Lisp was very powerful when it was first designed, and it improved its running speed in the next twenty years. And those so-called mainstream languages are designed with faster running speed as the starting point, and then become stronger step by step in more than 40 years.
Until today, the most advanced mainstream languages are just approaching the level of Lisp. Although it is close, it is still not as powerful as Lisp.
Fourth,
When Lisp was born, it contained nine new ideas. Some of them are familiar to us today, others have just appeared in other high-level languages, and two are unique to Lisp. According to the degree of public acceptance, these nine concepts are:
1. conditional structure (i.e. "if-then-else" structure). Now everyone takes this for granted, but Fortran I doesn't have this structure, it only has a goto structure based on the instructions of the underlying machine.
2. Function is also a data type. In Lisp language, a function is a data type just like an integer or a string. It has its own literal representation, which can be stored in variables or passed as parameters. It has all the functions that a data type should have.
3. Recursion. Lisp is the first high-level language that supports recursive functions.
4. Dynamic types of variables. In Lisp language, all variables are actually pointers, and the values they point to are different types, but the variables themselves are not. Copying a variable is equivalent to copying a pointer, not copying the data pointed to by the pointer.
5. Garbage collection mechanism.
6. The program consists of expressions. Lisp program is a collection of expression blocks, and each expression returns a value. This is very different from Fortran and most later languages. Their programs are composed of expressions and statements.
In Fortran I, it is natural to distinguish between expressions and statements, because it does not support statement nesting. So, if you need to calculate a value with a mathematical formula, you must return the value with an expression, and there is no other grammatical structure available, because otherwise you can't handle the value.
Later, the new programming language supported the block structure, of course, this restriction did not exist. But it is too late, and the distinction between expression and sentence is deeply rooted. It spread from Fortran to Algol and then to their successors.
7. Types of symbols. A symbol is actually a pointer to a string stored in a hash table. Therefore, to compare whether two symbols are equal, we only need to see whether their pointers are the same, rather than comparing them character by character.
8. The code uses a tree representation composed of symbols and constants.
9. The whole language is available at any time. Lisp does not really distinguish between reading period, compiling period and running period. Code can be compiled or run during reading; You can also read or run code at compile time; You can also read or compile code at run time.
Run the code during reading so that the user can reprogram the syntax of LISP; Running code at compile time is the basis of Lisp macro. Compile the translation code at runtime and let Lisp act as an extension language); In a project like Emacs. Reading code at runtime enables programs to communicate with each other through S expressions. Recently, the emergence of XML format has made this concept "pronounced" again.
Five,
When Lisp first appeared, its idea was quite different from other programming languages. The design idea of the latter is mainly determined by the hardware in the late 1950s. With the passage of time, popular programming languages are constantly updated, and language design ideas are gradually moving closer to Lisp.
Ideas 1 0 to 5 have been widely accepted. idea 6 began to appear in mainstream programming languages, and idea 7 was implemented in Python language, but there seems to be no special syntax.
Thought 8 is probably the most interesting point. It and Idea 9 only became part of Lisp by chance, because they did not belong to john mccarthy's original idea, but were added by his student Steve Russell. Since then, they have made Lisp look strange, but they have also become the most unique features of the language. Lisp's weird form is not because of its weird grammar, but because it has no grammar at all, and the program is directly expressed in the form of parsing tree. In other languages, this form is only generated in the background after parsing, while Lisp directly adopts it as the expression form. It consists of a list, which is the basic data structure of Lisp.
Facts have proved that it is a very powerful function to express a language with its own data structure. Ideas 8 and 9 mean that you can write a program that you can program yourself. This may sound strange, but it is very common for Lisp language. The most common method is to use macros.
The term "macro" in Lisp language has different meanings from other languages. Lisp macros are all-encompassing It may be an abbreviated form of an expression or a compiler for a new language. If you want to really understand the Lisp language or broaden your programming horizon, then you must learn macros.
As far as I know, macros (defined by Lisp language) are still unique to Lisp. One reason is that in order to use macros, you may have to make your language look as weird as Lisp. Another possible reason is that if you want to add this ultimate weapon to your own language, you can't claim to have invented a new language since then, but you can only say that you have invented a new dialect Lisp.
I was joking, but that's the way it is. If you use car, cdr, cons, quote, cond, atom, eq and other functions to create a new language, and write the functions as a list representation, you can completely deduce all other parts of the Lisp language based on them. In fact, Lisp language is defined in this way, and john mccarthy designed the language in this way, which makes this deduction possible.
Six,
Even though Lisp does represent a direction that mainstream programming languages are approaching, does it mean that you should use it to program?
How much will you lose if you use less powerful language? Isn't it a wise choice not to use the most advanced technology sometimes? So many people use mainstream programming languages, doesn't that in itself show that those languages have merit?
On the other hand, it doesn't matter which programming language you choose. Anyway, different languages can get the job done. Generally speaking, the more demanding the project, the more effective the programming language will be. However, countless projects are not restricted by harsh conditions at all. For most programming tasks, you may just write some small programs and connect them with glue language. You can write these small programs in the programming language you are familiar with, or you can write them in the language with the most powerful function library for a specific project. If you only need to transfer data between Windows applications, you can still achieve your goal by using Visual Basic.
So, what are the programming advantages of Lisp?
Seven,
The more powerful the programming ability of the language, the shorter the written program (of course, not the number of characters, but an independent grammatical unit).
The amount of code is very important, because the time spent developing a program mainly depends on the length of the program. If the code written in one language is three times longer than that written in another language for the same software, it means that it will take you three times longer to develop. And even if you hire more people, it will not help to reduce the development time, because when the team size exceeds a certain threshold, adding more people will only bring net losses. Fred Brooks described this phenomenon in his masterpiece "The Myth Man Month", and what I saw and heard confirmed his statement.
How short can you make the program if you use Lisp language? Take the comparison between Lisp and C as an example. Most of the statements I have heard are that the length of C code is 7 times to 10 times that of Lisp. But recently there was an article in New Architect magazine introducing ITA software company, saying that "one line of Lisp code is equivalent to 20 lines of C code". Because this article quoted the president of ITA, I think this figure comes from ITA's programming practice. If so, then we can believe this sentence. ITA's software not only uses Lisp language, but also uses C and C++ at the same time, so this is their experience.
According to the above picture, if you compete with ITA and you develop software in C language, ITA will develop 20 times faster than you. If it takes you a year to implement a function, it only takes less than three weeks. Conversely, if a new function has been developed for three months, it will take you five years to make it.
Do you know that?/You know what? Do you know that?/You know what? The above comparison only considers the best case. When we only compare the number of codes, the implication is that if we use a weak language, we can also develop the same software. But in fact, there is a limit to what programmers can do in a certain language. If you want to use a low-level language to solve a difficult problem, then you will face all kinds of extremely complicated and even unclear situations.
So, when I said that if you compete with ITA, what you made in five years, ITA can finish it in three months with the help of Lisp language. I mean five years when everything went smoothly, without any mistakes or much trouble. In fact, according to the actual situation of most companies, the project planned to be completed in five years will probably never be completed.
I admit that the above example is too extreme. ITA seems to have a group of clever hackers, and C language is a very low-level language. But in the highly competitive market, even if the development speed is only two or three times, it is enough to keep you in a backward position forever.
- Previous article:Walking businessman
- Next article:Poisonous tongue and black vomiting.
- Related articles
- Yichang boy lost his legs in a car accident and still stubbornly studied! How do you motivate yourself when you meet the bottom of your life?
- After five years of divorce, I wanted to remarry, but my daughter said, don't drag me down when you are old. What should I do?
- Tell me a joke. Try to be funny.
- Joke Tianjin
- 100 humorous chat topics, 100 times more interesting than what you are doing
- The more jokes about animals, the better ~ ~ ~
- Ma Baiwan and Yang Yeqing argued about Ma Chun's marriage. Ma Chun firmly disagreed with Ma Chun's divorce. When Ma Chun heard the news, she ran to her mother's grave and cried, and accidentally rolle
- Joke wail.
- Who are the members of the Backhouse Boys?
- What does it mean to get off in the glory of the king?