1: sq.c 这个程序就是为了测试电脑里面数的最大值到底可以表示多少,当达到最大值时又会发生什么。 代码为:
#include <stdio.h> #include <stdlib.h> int sq(int x) { return x*x; //返回一个平方值。 } //argc为存放命令行的参数个数,且函数名也包括其中,所以其值至少为1。 //argv是指向一个命令行的参数,所有命令行参数都是字符串。argv[0]指向第一个参数,既函数名 int main(int argc, char *argv[]) { int i; for (i = 1; i < argc; i++) { int x = atoi(argv[i]); //atoi是一个函数名,意思是把字符串转换成整型数。 int sx = sq(x); //调用函数sq printf("sq(%d) = %d\n", x, sx); } return 0;**加粗样式** } //下面是测试数据和结果。 /*@ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 12 sq(12) = 144 @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 65535 sq(65535) = -131071 @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 40000 sq(40000) = 1600000000 @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 50000 sq(50000) = -1794967296 @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 400000 sq(400000) = 1086210048 @ubuntu:/mnt/hgfs/share/csapp_code$ ./a.out 500000 sq(500000) = 891896832 */我们可以看到计算机里面可以存储40000的平方,但当为50000的平方时,其平方值变为负数了。所以这部分就是发生了溢出,超过了最大值,而进行了模运算,刚好就变为了一个负数。而当400000,500000的平方时又变为了正数,但值不正确。这就是这个平方值对最大值进行了模运算刚好为正数。