《C程序设计语言》笔记----第一章 导言


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是什么

 

在这里先回答第二个问题,EOFend 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(补码形式,321

好,现在我们看下面三行代码:

char ch = EOF;/*EOF赋值给ch*/

printf("%d/n", ch);/*打印ch*/

printf("%d/n", ch==EOF);/*比较chEOF*/

/*Output

-1

1

*/

这又说明了什么?

int长度为4字节,char长度为1字节,将int类型的值赋值给char类型变量时,会取int类型的低8位赋值给char类型的变量。对应于上边的程序,

ch = EOF;

执行完此语句后,ch的值变为:0xFF。它的值还是-1

接下来执行这一句:ch==EOF

ch是一个字节,而EOF4个字节,按照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类型吧。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值