Day 4
修饰符
*定义宏的时候涉及到算式 尽量加圆括号()
一种测试方法 以及错误
#include <stdio.h>
#include <stdlib.h>
int main()
{
printf( “[%s:%d] before while() .” , __FUNCTION__ , __LINE__ );
while(1);
printf( “[%s:%d] after while() .” , __FUNCTION__ , __LINE__ );
exit(0);
}
事实上 这里的before是打印不出来的 这里涉及到缓冲机制 因为涉及到终端设备 全缓冲模式就实际上是行缓冲模式 只有遇到/n才会刷新缓冲区
在这里 before 没有/n 是被放置在输出缓冲区当中的 这种情况下 要么程序结束自动刷新IO 要么等到特定的语句刷新 要么缓冲区载满 一次性自动刷新 不然不会看到before 被打印出来
所以 若非特定格式的要求 不允许换行 那么尽量使用 /n 作为一个输出的结尾 这会避免一些错误的产生
printf( “[%s:%d] before while() ./n” , __FUNCTION__ , __LINE__ );
显然 这样的格式更加科学
‘
scanf 的使用是需要比较谨慎的 因为在输入的时候很容易因为输入格式的不正确性导致程序的崩溃 而正确的用法是将scanf的返回值利用起来 这样 在scanf输入产生错误的时候,就可以通过对返回值进行判断而及时的推出错误
#include <stdio.h>
#include <stdlib.h>
int main()
{
int i=0;
int ret=1;
printf( “Please enter:\n” );
while(1)
{
ret= scanf( “%d”, &i);
if(ret != 1)
{
printf(“Enter error!\n”);
break;
}
printf( “i=%d\n”, i );
}
exit(0);
}
抑制符的使用: 在scanf 中 抑制符的使用会明确scanf的输入 这一点比较好用 虽然输入不一定用到 sacnf
scanf(“%d”, &i);
sacnf(“%c”,&ch);
printf(“”i=%d,ch=%d\n,i,ch);
在输入的时候,我们习惯
数字(空格)字符
比如
90 a
但是这样输入时候输出的 内容为
90,32
其中 32 实际上是捕捉到了空格的ASCII码值 这显然不是我们期望的
于是抑制符的作用就体现出来了
将代码改为
scanf(“%d”, &i);
sacnf(“%*c%c”,&ch);
printf(“”i=%d,ch=%d\n,i,ch);
这样的话 在输入的时候按照
数字(空格)字符
比如
90 a 输入
输出的内容就是 90,97 就是正确的了
- Never use gets()
可以用fget 或者 getline 来替代 最好是getline