刚看了C程序设计语言这本教材,一开始就有很多迷惑不解的地方:
1.字符转换问题 char和int类型是如何转换的?
2.getchar()接收多个字符时,是如何依次打印出来的?
3.EOF是什么,如果打印出来它的值?
对于char类型,
在Java中,
数据类型是可以从低精度向高精度转换的
byte 、short、int、long、float、double、char
ex:
int i = 97;
char c = (char) i;
从高精度向低精度可以通过类包装器进行转换
ex:
char c = 'a';
int m = (int) c;
String s = "555";
int n = Integer.parseInt(s);
那么在C语言中呢:
从下面的一个示例中:
#include<stdio.h>
main()
{
int c = 97;
c=getchar();//@1
while(c != EOF) {
putchar(c);
printf("%d\n", c);
c = getchar();//@2
}
}
char类型是用来定义一个字符的,
当使用@1列的getchar()方法输入一个字符串时,c只读取第一个字符,
然后打印出c的值,再通过@2列的getchar()方法遍历剩余的字符,直到结束。
putchar()函数可以将int类型转换为char类型。
打印EOF的值:
printf("%d\n", EOF);
手动输入结束符:在Linux的shell中是Ctrl + D
这里还有一个问题,为什么将保存字符的对象定义成int类型呢,根据书上的意思,char类型专门用于存储这种字符型数据,当然任何int也可以用于存储字符数据,但是由于EOF是一个整形数,与任何char类型的值都不相同,所以为了防止getchar的时候产生溢出,将对象定义成int类型。