Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

Structure and Interpretation of Computer Programs

From Wikipedia, the free encyclopedia
(Redirected fromJulie Sussman)
Computer science textbook
"SICP" redirects here. For other uses, seeSICP (disambiguation).
Structure and Interpretation of Computer Programs (SICP)
Cover of the second edition
AuthorHarold Abelson,Gerald Jay Sussman, Julie Sussman
SubjectComputer science
GenreTextbook
PublisherMIT Press
Publication date
1984 (1st ed.), 1996 (2nd ed.), 2022 (JavaScript ed.)
Pages657
ISBN0-262-51087-1 (2nd ed.)
LC ClassQA76.6 .A255 1996
Websitemitpress.mit.edu/sicp

Structure and Interpretation of Computer Programs (SICP) is acomputer science textbook byMassachusetts Institute of Technology professorsHarold Abelson andGerald Jay Sussman with Julie Sussman. It is known as the "Wizard Book" inhacker culture.[1] It teaches fundamental principles ofcomputer programming, includingrecursion,abstraction,modularity, andprogramming languagedesign andimplementation.

MIT Press published the first edition in 1984, and the second edition in 1996. It was used as the textbook for MIT's introductory course incomputer science from 1984 to 2007. SICP focuses on discovering generalpatterns for solving specific problems, and buildingsoftware systems that make use of those patterns.[2]

MIT Press published aJavaScript version of the book in 2022.[3]

Content

[edit]

The book describes computer science concepts usingScheme, a dialect ofLisp. It also uses avirtualregister machine andassembler to implement Lispinterpreters andcompilers.

Topics in the books are:

Chapter 1: BuildingAbstractions withProcedures

[edit]
  1. The Elements of Programming
  2. Procedures and theProcesses They Generate
  3. Formulating Abstractions with Higher-Order Procedures

Chapter 2: Building Abstractions withData

[edit]
  1. Introduction to Data Abstraction
  2. Hierarchical Data and theClosure Property
  3. Symbolic Data
  4. Multiple Representations for Abstract Data
  5. Systems with Generic Operations

Chapter 3: Modularity,Objects, andState

[edit]
  1. Assignment andLocal State
  2. The Environment Model of Evaluation
  3. Modeling with Mutable Data
  4. Concurrency: Time Is of the Essence
  5. Streams

Chapter 4:Metalinguistic Abstraction

[edit]
  1. TheMetacircular Evaluator
  2. Variations on a Scheme –Lazy Evaluation
  3. Variations on a Scheme –Nondeterministic Computing
  4. Logic Programming

Chapter 5: Computing withRegister Machines

[edit]
  1. DesigningRegister Machines
  2. A Register-Machine Simulator
  3. Storage Allocation andGarbage Collection
  4. The Explicit-Control Evaluator
  5. Compilation

Characters

[edit]

Several humorously-named fictional characters appear in the book:

  • Alyssa P. Hacker, a Lisphacker
  • Ben Bitdiddle
  • Cy D. Fect, a "reformed C programmer"
  • Eva Lu Ator
  • Lem E. Tweakit
  • Louis Reasoner, a "loose reasoner"

License

[edit]

The book is licensed under aCreative Commons Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.[4]

Coursework

[edit]

The book was used as the textbook for MIT's former introductory programming course, 6.001,[5] from fall 1984 through its last semester, in fall 2007.[6] Other schools also made use of the book as a course textbook.[7]

Reception

[edit]

Byte recommended SICP in 1986 "for professional programmers who are really interested in their profession". The magazine said that the book was not easy to read, but that it would expose experienced programmers to both old and new topics.[8]

A review of SICP as an undergraduate textbook byPhilip Wadler noted the weaknesses of the Scheme language as an introductory language for a computer science course.[9] Wadler criticized in particular the lack ofpattern matching, obscuringequational reasoning and making the teaching of proofs harder; the lack ofalgebraic data types in Scheme and the over-reliance oncons pairs for both code and data representation, which can confuse beginning students; and the choice ofstrict instead oflazy evaluation as the standard evaluation strategy.

Influence

[edit]

SICP has been influential in computer science education, and several later books have been inspired by its style.

See also

[edit]

References

[edit]
  1. ^Raymond, Eric S.; Steele, Guy (1991).The New hacker's dictionary. Internet Archive. Cambridge, Massachusetts: MIT Press.ISBN 978-0-262-68069-1.
  2. ^Harvey, B (2011),"Why SICP matters?",The 150th anniversary of MIT,Boston Globe.
  3. ^Structure and Interpretation of Computer Programs: JavaScript Edition. MIT Press. 2022.ISBN 9780262543231.
  4. ^"SICP". MIT Press. Archived fromthe original on 2017-12-26. Retrieved2007-11-11..
  5. ^"Electrical Engineering and Computer Science; 6.001 Structure and Interpretation of Computer Programs".OpenCourseWare. MIT. Spring 2005. Retrieved2020-06-21.
  6. ^Guy, Donald, "The End of an Era",MIT Admissions (blog comment), archived fromthe original on 2018-08-21, retrieved2008-08-05,I talked to Professor Sussman on the phone... He said that he'd actually been trying to have 6.001 replaced for the last ten years (and I read somewhere that Professor Abelson was behind the move too). Understanding the principles is not essential for an introduction to the subject matter anymore. He sees 6.001 as obsolete.
  7. ^"Universities and Colleges Using SICP". MIT Press. Archived fromthe original on 2022-04-23. Retrieved2022-03-30.
  8. ^Kilov, Haim (November 1986).Byte Magazine Volume 11 Number 12: Knowledge Representation. p. 70.
  9. ^Wadler, P (1987-03-01)."A critique of Abelson and Sussman or why calculating is better than scheming".ACM SIGPLAN Notices.22 (3):83–94.doi:10.1145/24697.24706.ISSN 0362-1340.

External links

[edit]
Features
Object systems
Implementations
Standardized
Common
Lisp
Scheme
ISLISP
Unstandardized
Logo
POP
Operating system
Hardware
Community
of practice
Technical standards
Education
Books
Curriculum
Organizations
Business
Education
People
Common
Lisp
Scheme
Logo
POP
International
Other
Retrieved from "https://en.wikipedia.org/w/index.php?title=Structure_and_Interpretation_of_Computer_Programs&oldid=1305056794"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2026 Movatter.jp