计算机系统漫游
引子
本文标题取自计算机书籍《Computer Systems A Programmer's perspective》的序章,国内通常的书名翻译是《深入理解计算机系统》。该文是个人对本书及对应的CMU课程15213 Introduction to Computer Systems 的观点记录。后续我将用三个月左右的时间将对于本书的理解记录成文章表达出来。
二进制的世界
系统中的所有信息——包括磁盘文件、内存中的程序、内存中存放的用户数据以及网络上传输的数据,都是由一串比特表示的。当我们在计算机内输入乘法指令:200 * 300 * 400 * 500 ,会得到一个完全偏离数学逻辑的答案:-884901888 。显然这违背了整数计算的特性,计算一组正数的乘积不应产生一个为负的结果。在学习计算机的信息表示与处理的时候我们知道:现代计算机存储和处理的信息以二值信号表示,这些微不足道的二进制数字,称之为位(bit)。而之所以会产生这种错误,是因为计算机的表示法是用有限数量的位来对一个数字编码,因此,当结果太大以至于不能表示时,某些运算就会溢出(overflow),溢出会导致令人吃惊的结果。计算机表示实数采用的是浮点数,有着专门的算术标准,即IEEE754。
(1996年6月4日,Ariane5火箭初次航行,一个错误便产生了灾难性的后果。该火箭发射后