Translate the first three subsections of Subject guides

This commit is contained in:
keithnull
2019-10-08 17:04:09 +08:00
parent 556b8dc5b0
commit 0282d35d9a

View File

@ -17,12 +17,12 @@
| --- | --- | --- | --- |
| **[编程](#编程)** | 不要做一个“永远没彻底搞懂”诸如递归等概念的程序员。| _《计算机程序的构造和解释》_ | Brian Harveys Berkeley CS 61A |
| **[计算机架构](#计算机架构)** | 如果你对于计算机如何工作没有具体的概念,那么你所做出的所有高级抽象都是空中楼阁。 | _《计算机组成与设计》_ | Berkeley CS 61C |
| **[算法与数据结构](#算法)** | 如果你不懂得如何使用栈、队列、树、图等常见数据结构,遇到有难度的问题时,你将束手无策。| _《算法设计手册》_ | Steven Skienas lectures |
| **[数学知识](#数学)** | 计算机科学基本上是应用数学的一个“失控的”分支,因此学习数学将会给你带来竞争优势。| _《计算机科学中的数学》_ | Tom Leightons MIT 6.042J |
| **[算法与数据结构](#算法和数据结构)** | 如果你不懂得如何使用栈、队列、树、图等常见数据结构,遇到有难度的问题时,你将束手无策。| _《算法设计手册》_ | Steven Skienas lectures |
| **[数学知识](#数学知识)** | 计算机科学基本上是应用数学的一个“失控的”分支,因此学习数学将会给你带来竞争优势。| _《计算机科学中的数学》_ | Tom Leightons MIT 6.042J |
| **[操作系统](#操作系统)** | 你所写的代码,基本上都由操作系统来运行,因此你应当了解其运作的原理。 | _《操作系统导论》_ | Berkeley CS 162 |
| **[计算机网络](#计算机网络)** | 互联网已然势不可挡:理解工作原理才能解锁全部潜力。 | _《计算机网络自顶向下方法》_ | Stanford CS 144 |
| **[数据库](#数据库)** | 对于多数重要程序,数据是其核心,然而很少人理解数据库系统的工作原理。 | _Readings in Database Systems 暂无中译本_ | Joe Hellersteins Berkeley CS 186 |
| **[编程语言与编译器](#编程语言)** | 若你懂得编程语言和编译器如何工作,你就能写出更好的代码,更轻松地学习新的编程语言。| _《编译原理》_ | Alex Aikens course on Lagunita |
| **[编程语言与编译器](#编程语言与编译器)** | 若你懂得编程语言和编译器如何工作,你就能写出更好的代码,更轻松地学习新的编程语言。| _《编译原理》_ | Alex Aikens course on Lagunita |
| **[分布式系统](#分布式系统)** | 如今_多数_ 系统都是分布式的。 | _《分布式系统原理与范型》第三版_ Maarten van Steen著 | 🤷‍ |
## 为什么要学习计算机科学?
@ -44,3 +44,69 @@
>
> — Jenna Bilotta (@jenna) [2017年3月4日](https://twitter.com/jenna/status/838161631662092289)
## 分科目指引
### 编程
大多数计算机专业本科教学以程序设计“导论”作为开始。这类课程的最佳版本不仅能满足初学者的需要,还适用于那些在初学编程阶段遗漏了某些有益的概念和程序设计模式的人。
对于这部分内容,我们的标准推荐是这部经典著作:《计算机程序的构造和解释》。在网络上,这本书既可供[免费阅读(英文版)](https://mitpress.mit.edu/sites/default/files/sicp/full-text/book/book.html),也作为[MIT的免费视频课程](http://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-001-structure-and-interpretation-of-computer-programs-spring-2005/video-lectures/)。不过尽管这些视频课程很不错,我们对于视频课程的推荐实际上是[Brian Harvey 开设的 SICP 课程](https://archive.org/details/ucberkeley-webcast-PL3E89002AA9B9879E?sort=titleSorter)(即 Berkeley 的 61A 课程。比起MIT的课程它更加完善更适用于初学者。
我们建议至少学完SICP的前三章并完成配套的习题。如果需要额外的练习可以去解决一些小的程序设计问题比如[exercism](http://exercism.io)。
如果你觉得SICP过于难那我们推荐 _[How to Design Programs](http://www.htdp.org/)_ 如果你觉得SICP过于简单那我们推荐 _[Concepts, Techniques, and Models of Computer Programming](https://smile.amazon.com/Concepts-Techniques-Models-Computer-Programming/dp/0262220695/)_
### 计算机架构
计算机架构——有时候又被称为“计算机系统”或者“计算机组成”——是了解软件底层的的重要视角。根据我们的经验,这是自学的软件工程师最容易忽视的领域。
_The Elements of Computing Systems_又名“从与非门到俄罗斯方块”“Nand2Tetris”这本书规模宏大让读者对计算机内的所有部分如何协同工作有完全的认识。这本书的每一章节对应如何构建计算机整体系统中的一小部分
从用HDL硬件描述语言写基本的逻辑门电路出发途经CPU和汇编最终抵达诸如俄罗斯方块这般规模的应用程序。
我们推荐把此书的前六章读完,并完成对应的项目练习。这么做,你将更加深入地理解,计算机架构和运行其上的软件之间的关系。
这本书的前半部分(包括所有对应的项目)均可从[Nand2Tetris的网站上](http://www.nand2tetris.org)免费获得。同时在Coursera上这是一门[视频课程](https://www.coursera.org/learn/build-a-computer)。
为了追求简洁和紧凑,这本书牺牲了内容上的深度。尤其值得注意的是,流水线和存储层次结构是现代计算机架构中极其重要的两个概念,然而这本书对此几乎毫无涉及。
当你掌握了Nand2Tetris的内容后我们接下来推荐Patterson和Hennessy二人所著的 _[《计算机组成与设计》](https://smile.amazon.com/Computer-Organization-Design-Fifth-Architecture/dp/0124077269)_一本优秀的经典著作。这本书中的不同章节重要程度不一因此我们建议根据Berkeley的[CS61C课程](http://inst.eecs.berkeley.edu/~cs61c/sp15/) “计算机架构中的伟大思想”来着重阅读一些章节。这门课的笔记和实验在网络上可以免费获得,并且在[互联网档案](https://archive.org/details/ucberkeley-webcast-PL-XXv-cvA_iCl2-D-FS5mk0jFF6cYSJs_)中有这门课程的过往资料。
[![Elements of Computing Systems](https://teachyourselfcs.com/elements-computing-systems.jpg)](http://www.nand2tetris.org)
> 硬件是平台。
>
> — Mike Acton, Engine Director at Insomniac Games
([观看他在CppCon上的演说](https://www.youtube.com/watch?v=rX0ItVEVjHc))
### 算法与数据结构
正如几十年来的共识,我们认为,计算机科学教育所赋予人们的最大能量在于对常见算法和数据结构的熟悉。此外,这也可以训练一个人对于各种问题的解决能力,有助于其他领域的学习。
关于算法与数据结构有成百上千的书可供使用但是我们的最爱是Steven Skiena编写的 _[《算法设计手册》](https://smile.amazon.com/Algorithm-Design-Manual-Steven-Skiena/dp/1848000693/)_。显而易见他对此充满热爱迫不及待地想要帮助其他人理解。在我们看来这本书给人一种焕然一新的体验完全不同于那些更加经常被推荐的书比如CormenLeisersonRivest 和 Stein或者 Sedgewick的书后两者充斥着过多的证明不适合以 _解决问题_ 为导向的学习)。
如果你更喜欢视频课程,[Skiena慷慨地提供了他的课程](https://www.youtube.com/watch?v=A2bFN3MyNDA&list=PLOtl7M3yp-DX32N0fVIyvn7ipWKNGmwpp)。此外Tim Roughgarden的课程也很不错
在Stanford的MOOC平台Lagunita或者[Coursera](https://www.coursera.org/specializations/algorithms)上均可获得。Skiena和Roughgarden的这两门课程没有优劣之分选择何者取决于个人品味。
至于练习,我们推荐学生在[Leetcode](https://leetcode.com)上解决问题。Leetcode上的问题往往有趣且带有良好的解法和讨论。此外在竞争日益激烈的软件行业这些问题可以帮助你评估自己应对技术面试中常见问题的能力。我们建议解决大约100道随机挑选的Leetcode问题作为学习的一部分。
最后,我们强烈推荐 _[How to Solve It](https://smile.amazon.com/How-Solve-Mathematical-Princeton-Science/dp/069116407X/)_。这本书极为优秀且独特,指导人们解决广义上的问题,因而一如其适用于数学,它适用于计算机科学。
[![算法设计手册](https://teachyourselfcs.com/skiena.jpg)](https://smile.amazon.com/Algorithm-Design-Manual-Steven-Skiena/dp/1848000693/) [![How to Solve It](https://teachyourselfcs.com/polya.jpg)](https://smile.amazon.com/How-Solve-Mathematical-Princeton-Science/dp/069116407X/)
> 我可以广泛推荐的方法只有一个: 写之前先思考。
>
>— Richard Hamming
### 数学知识
### 操作系统
### 计算机网络
### 数据库
### 编程语言与编译器
### 分布式系统