Programming Language Pragmatics
暫譯: 程式語言實用主義

Michael L. Scott

  • 出版商: Morgan Kaufmann
  • 出版日期: 1999-10-25
  • 售價: $1,078
  • 語言: 英文
  • 頁數: 858
  • 裝訂: Hardcover
  • ISBN: 1558604421
  • ISBN-13: 9781558604421
  • 已過版

買這商品的人也買了...

相關主題

商品描述


Order This Book | Authors | Contents | Web-Enhanced | Related Titles

"Michael Scott's book could have been entitled: Why Programming Languages Work. It takes a fresh look at programming languages by bringing together ideas and techniques usually covered in disparate language design, compiler, computer architecture, and operating system courses. Its comprehensive and integrated presentation of language design and implementation illustrates and explains admirably the many deep and profitable connections among these fields."
- Jim Larus, Microsoft Research

Programming Language Pragmatics addresses the fundamental principles at work in the most important contemporary languages, highlights the critical relationship between language design and language implementation, and devotes special attention to issues of importance to the expert programmer. Thanks to its rigorous but accessible teaching style, youll emerge better prepared to choose the best language for particular projects, to make more effective use of languages you already know, and to learn new languages quickly and completely.

Features

  • Addresses the most recent developments in programming language design, spanning more than forty different languages, including Ada 95, C, C++, Fortran 95, Java, Lisp, Scheme, ML, Modula-3, Pascal, and Prolog.
  • Places a special emphasis on implementation issueshow the techniques used by compilers and related tools influence language design, and vice versa.
  • Covers advanced topics in language design and implemenation, such as iterators, coroutines, templates (generics), separate compilation, I/O, type inference, and exception handling.
  • Reviews language-related topics in assembly-level architecture critical for understanding what a compiler does to a program.
  • Offers in-depth coverage of object-oriented programming, including multiple inheritance and dynamic method binding.
  • Devotes a special section to static and dynamic linking.
  • Includes a comprehensive chapter on concurrency, with detailed coverage of both shared-memory and message-passing languages and libraries.
  • Provides an accessible introduction to the formal foundations of compilation (automata theory), functional programming (lambda calculus), and logic programming (predicate calculus).

Authors:

Michael L. Scott is a professor in the University of Rochesters Department of Computer Science, which he chaired from 1996 to 1999. He is the designer of the Lynx distributed programming language and a co-designer of the Charlotte and Psyche parallel operating systems, the Bridge parallel file system, the Cashmere distributed shared memory system, and the MCS mutual exclusion lock. He received his Ph.D. from the University of Wisconsin-Madison in 1985.

Table of Contents:

Preface
1 Introduction
2 Programming Language Syntax
3 Names, Scopes, and Bindings
4 Semantic Analysis
5 Assembly-Level Computer Architecture
6 Control Flow
7 Data Types
8 Subroutines and Control Abstraction
9 Building a Runnable Program
10 Data Abstraction and Object Orientation
11 Nonimperative Programming Models: Functional and Logic Languages
12 Concurrency
13 Code Improvement
Appendices

Web-Enhanced:

From the author's page for Programming Language Pragmatics:

For Instructors
  • Solutions for exercises
    INSTRUCTORS PLEASE READ

    Our standard request is that you not post solutions online and that you take precautions to protect the integrity of our password protected sites. We have been notified that students are searching the internet for answers to their homework exercises from other instructors' websites. We are requesting that everyone respect the need to restrict access to this material and take adequate precautions to prevent access to solutions by students not in your own courses if you choose to post them on the Web.

    Request a password from your academic sales representative.

Other titles covering compiler design:

Advanced Compiler Design and Implementation by Steven S. Muchnick covers advanced issues in the design and implementation of compilers for modern processors. Written for professionals and graduate students, it guides readers in designing and implementing highly optimizing compilers for real-world languages.

Related Titles:

Software Engineering & Programming



商品描述(中文翻譯)





訂購本書
| 作者
| 內容
| 網路增強
| 相關書籍

'Michael Scott 的書本可以命名為:為什麼程式語言有效。 它以全新的視角來看待程式語言,將通常在不同的語言設計、編譯器、計算機架構和作業系統課程中涵蓋的想法和技術結合在一起。它對語言設計和實現的全面且整合的呈現,出色地說明和解釋了這些領域之間的許多深刻且有利的聯繫。'

- Jim Larus, 微軟研究

程式語言實用學 探討了當前最重要語言中的基本原則,突顯了語言設計與語言實現之間的關鍵關係,並特別關注對專業程式設計師重要的議題。得益於其嚴謹但易於理解的教學風格,您將更好地準備選擇適合特定專案的最佳語言,更有效地使用您已知的語言,並快速且徹底地學習新語言。

特色


  • 涵蓋了程式語言設計的最新發展,涉及超過四十種不同的語言,包括 Ada 95、C、C++、Fortran 95、Java、Lisp、Scheme、ML、Modula-3、Pascal 和 Prolog。

  • 特別強調實現問題——編譯器和相關工具所使用的技術如何影響語言設計,反之亦然。

  • 涵蓋語言設計和實現中的進階主題,如迭代器、協程、模板(泛型)、獨立編譯、I/O、類型推斷和例外處理。

  • 回顧與語言相關的主題,這些主題在組合級架構中對理解編譯器對程式的操作至關重要。

  • 深入探討物件導向程式設計,包括多重繼承和動態方法綁定。

  • 專門設置一個部分來討論靜態和動態連結。

  • 包括一章全面介紹並發,詳細涵蓋共享記憶體和訊息傳遞語言及庫。

  • 提供對編譯的形式基礎(自動機理論)、函數式程式設計(λ演算)和邏輯程式設計(謂詞演算)的易懂介紹。


作者:

Michael L. Scott 是羅徹斯特大學計算機科學系的教授,該系他於1996年至1999年擔任系主任。他是 Lynx 分散式程式語言的設計者,也是 Charlotte 和 Psyche 平行作業系統、Bridge 平行檔案系統、Cashmere 分散式共享記憶體系統和 MCS 互斥鎖的共同設計者。他於1985年獲得威斯康辛大學麥迪遜分校的博士學位。

目錄:


前言

1 介紹

2 程式語言語法

3 名稱、範圍和綁定

4 語意分析

5 組合級計算機架構

6 控制流程

7 資料類型

8 子程式和控制抽象

9 建立可執行程式

10 資料抽象和物件導向

11 非命令式程式設計模型:函數式和邏輯語言

12 並發

13 程式碼改進

附錄

網路增強:


來自 作者頁面程式語言實用學:

對於講師


  • 練習解答

    講師請閱讀


    我們的標準要求是您不要在網上發布解答,並且採取預防措施以保護我們的密碼保護網站的完整性。我們已被通知,學生正在搜尋網路上其他講師網站的作業解答。我們要求每個人尊重限制訪問這些資料的必要性,並採取適當的預防措施,以防止非您自己課程的學生訪問解答,如果您選擇在網上發布它們。



    請向您的學術銷售代表請求密碼。


其他涵蓋編譯器設計的書籍:



進階編譯器設計與實作
由 Steven S. Muchnick 撰寫,涵蓋現代處理器編譯器設計與實作的進階議題。這本書是為專業人士和研究生撰寫的,指導讀者設計和實作針對現實世界語言的高效能編譯器。

相關書籍:


軟體工程與程式設計






最後瀏覽商品 (20)