《C程序设计语言》笔记----第一章 导言
2011-04-18 21:05
232 查看
在C语言中所有变量都必须先声明后使用。声明通常放在函数起始处,在任何可执行语句之前。
一个打印华氏温度与摄氏温度对照表的程序:
公式:C =
(5/9)(F-32)
代码如下:
代码中隐藏的学问:
赋值语句:ceisius = 5 * (fahr-32) / 9;
在该语句中之所以不把表达式写成5/9*(fahr-32)。其原因是C语言及许多其他语言,整数除法操作将执行舍位,结果中的任何小数部分都会被舍弃。由于5/9相除后所得结果为0,因此求得所有的摄氏温度都将为0.
一个回显程序
代码中隐藏的学问
1.
我们读取的是字符,为什么将c声明为一个int类型
2.
EOF是什么
在这里先回答第二个问题,EOF(end of file)在C语言中用来代表输入结束的特殊值,它是一个整数。当没有输入时getchar()函数将返回EOF。
EOF定义在stdio.h这个头文件中:#define EOF (-1)
我们可以使用下面这天语句输出EOF的值:
printf("%d/n",
EOF);
现在再来回答第一个问题,如果我们不考虑文件结束,那么我们完全可以将c声明为char类型。前边说过EOF是整数值-1,所以考虑到输入结束是必须将c声明为int 类型,以保存EOF。
这个解释貌似合理
让我们再往深处想一想
EOF表示-1,
它在计算机中的表示形式是:0xFFFF(补码形式,32个1)
好,现在我们看下面三行代码:
char ch = EOF;/*将EOF赋值给ch*/
printf("%d/n",
ch);/*打印ch*/
printf("%d/n",
ch==EOF);/*比较ch与EOF*/
/*Output
-1
1
*/
这又说明了什么?
int长度为4字节,char长度为1字节,将int类型的值赋值给char类型变量时,会取int类型的低8位赋值给char类型的变量。对应于上边的程序,
ch = EOF;
执行完此语句后,ch的值变为:0xFF。它的值还是-1。
接下来执行这一句:ch==EOF
ch是一个字节,而EOF是4个字节,按照C语言的数据类型转化规则,自动转换将“范围小的”操作数转换为“范围较大”的操作数的类型。也就是说,这里系统要先将ch转化int型的数据,然后再与EOF进行比较,通过上边运行结果我们发现,ch==EOF结果为真,这是因为在char类型转换为int类型时进行了符号扩展,使用char的符号位填充了高位字节。有兴趣的可以参考这里http://blog.csdn.net/weizhee/archive/2006/10/26/1351455.aspx
经过这段讨论,貌似将c声明为char类型也没问题,可是在本书第二章中有这样一段话:当把一个char类型的变量转换为int类型的值时,对于不同的机器器结果也不同。在某些机器中,如果char类型值的最左一位为1,则转化为负整数(进行符号扩展)。而在另一些机器中,吧char类型转换为int类型是,在char类型值的左边填0,这样导致转换结果值总是正值。
所以为了保证代码的可移植性,最好还是将c声明为int类型吧。
一个打印华氏温度与摄氏温度对照表的程序:
公式:C =
(5/9)(F-32)
代码如下:
#include<stdio.h> /*公式:C = (5/9)(F-32)*/ /*当fahr=0,20, 40, …, 300分别打印华氏温度与摄氏温度对照表*/ int main() { /*变量的声明应放在函数开头,在任何可执行语句之前*/ int fahr, ceisius; int lower, upper, step; lower = 0; /*温度表的下限*/ upper = 300; /*温度表的上限*/ step = 20; /*步长*/ fahr = lower; while (fahr<=upper) { /*此处不能写成:ceisius = 5/9*(fahr-32);*/ ceisius = 5 * (fahr-32) / 9; printf("%d/t%d/n", fahr, ceisius); fahr += step; } return 0; }
代码中隐藏的学问:
赋值语句:ceisius = 5 * (fahr-32) / 9;
在该语句中之所以不把表达式写成5/9*(fahr-32)。其原因是C语言及许多其他语言,整数除法操作将执行舍位,结果中的任何小数部分都会被舍弃。由于5/9相除后所得结果为0,因此求得所有的摄氏温度都将为0.
一个回显程序
#include<stdio.h> int main() { int c; while ((c=getchar())!=EOF) putchar(c); return 0; }
代码中隐藏的学问
1.
我们读取的是字符,为什么将c声明为一个int类型
2.
EOF是什么
在这里先回答第二个问题,EOF(end of file)在C语言中用来代表输入结束的特殊值,它是一个整数。当没有输入时getchar()函数将返回EOF。
EOF定义在stdio.h这个头文件中:#define EOF (-1)
我们可以使用下面这天语句输出EOF的值:
printf("%d/n",
EOF);
现在再来回答第一个问题,如果我们不考虑文件结束,那么我们完全可以将c声明为char类型。前边说过EOF是整数值-1,所以考虑到输入结束是必须将c声明为int 类型,以保存EOF。
这个解释貌似合理
让我们再往深处想一想
EOF表示-1,
它在计算机中的表示形式是:0xFFFF(补码形式,32个1)
好,现在我们看下面三行代码:
char ch = EOF;/*将EOF赋值给ch*/
printf("%d/n",
ch);/*打印ch*/
printf("%d/n",
ch==EOF);/*比较ch与EOF*/
/*Output
-1
1
*/
这又说明了什么?
int长度为4字节,char长度为1字节,将int类型的值赋值给char类型变量时,会取int类型的低8位赋值给char类型的变量。对应于上边的程序,
ch = EOF;
执行完此语句后,ch的值变为:0xFF。它的值还是-1。
接下来执行这一句:ch==EOF
ch是一个字节,而EOF是4个字节,按照C语言的数据类型转化规则,自动转换将“范围小的”操作数转换为“范围较大”的操作数的类型。也就是说,这里系统要先将ch转化int型的数据,然后再与EOF进行比较,通过上边运行结果我们发现,ch==EOF结果为真,这是因为在char类型转换为int类型时进行了符号扩展,使用char的符号位填充了高位字节。有兴趣的可以参考这里http://blog.csdn.net/weizhee/archive/2006/10/26/1351455.aspx
经过这段讨论,貌似将c声明为char类型也没问题,可是在本书第二章中有这样一段话:当把一个char类型的变量转换为int类型的值时,对于不同的机器器结果也不同。在某些机器中,如果char类型值的最左一位为1,则转化为负整数(进行符号扩展)。而在另一些机器中,吧char类型转换为int类型是,在char类型值的左边填0,这样导致转换结果值总是正值。
所以为了保证代码的可移植性,最好还是将c声明为int类型吧。
相关文章推荐
- 第一章导言的笔记与思考
- 《C程序设计语言》第一章导言
- 第一章导言的笔记与思考
- 《C程序设计语言》第一章导言
- python核心编程第二版第一章学习笔记
- MFC Windows程序设计(第二版)第一章笔记
- SICP笔记与习题-第一章
- JavaScript 中级笔记 第一章
- 《现代操作系统》精读与思考笔记 第一章 引论
- 信息检索导论 第一章 阅读笔记
- 白帽子讲安全学习笔记第一章
- SICP第一章学习笔记
- Java学习笔记——JAVA图形设计卷I AWT——第一章绪论
- 培训教材笔记-介绍&第一章
- java学习笔记|第一章:java平台概述|
- Linux程序设计-学习笔记-第一章
- 第一章 80X86微型计算机组织 学习笔记
- 汇编语言笔记第一章基础知识
- 第一章——导言(1)
- [学习笔记]Silverlight4 RIA 开发全程解析[项目全程记录]----第一章FitnessTrackerPlus应用程序概述