1、scanf和scanf_s
自从装上vs2019后就发现scanf不能用了,一用就报错,要用scanf_s来代替。原因是微软觉得scanf不安全,容易造成内容泄露,所以在2005年推出了scanf_s,后面的s就是safe的意思。下面用用几行代码来说明一下他们的区别:
char a, b, c;
int d;
float e;
scanf("%d%d%d", &a, &b, &c);
scanf_s("%d%d%d",&a,sizeof(a),&b, sizeof(b),&c, sizeof(c));
scanf_s("%d%f", &d, &e);
我们可以看到,scanf_s和scanf的区别就是在一次输入多个字符型数据时,scanf_s后面每一个元素后面都要加一个表明元素使用内存大小的参数(sizeof方法就是获取传入参数所占的内存大小),不加就会报内存冲突的错误。而当用scanf_s输入单个字符时,这个参数不加也没事。用scanf_s输入整形、浮点型数据时,这个参数反而不能加。
2、使用cin和cout时报错
cin和cout是iostre m里面的用法,使用之前需要先引入iostream函数库。
#include <iostream>
using namespace std;
3、cin输入浮点型数据
用cin输入浮点型的数据时,cin能输入char型和整形,但是不能输入浮点型,输入之后会损失精度,强制转换成浮点型。
4、连续多次执行读取char型的scanf_s语句时换行符被读取的问题
char a[4];
for (int i = 0; i < 4; i++)
{
scanf_s("%c", &a[i]);
printf(" a[%d]:%c\n", i,a[i]);
}
运行上面这几行代码
假设输入a按下enter 、输入b按下enter、输入c按下enter、输入d按下enter。一开始我以为结果应该是
但实际上结果却是:
思考一下为什么——
原因很简单,我们以为输入enter键后结束当前输入就完了,其实不是表面上这样,按下enter键后会把换行符存进缓存区,在输入整形、浮点型时计算机看到换行符和空格会忽略,但是输入字符型的数据时会读取空格和换行,于是我们第一次输入的字符和按下的enter都会被读取。
代码运行讲解:执行上面的代码时输入一个a,然后输入enter结束输入语句,缓存区就存了一个a、一个换行符。然后把a赋给a[0],换行符留在缓存区,第二次循环时会直接把换行符赋给a[1],然后a[1]输入立即结束,打印a[1]: ,这也是为什么第二次我们还没有输入就输出了;第三次循环时因为缓存区没有数据,会再让用户输入,然后又输入一个字符一个enter,这两个字符在接下来的两次循环中分别赋给a[2] a[3],运行结束。结果就是第二张图片里的那样。
那如何才能让运行结果符合我们之前的预期呢?其实也很好解决,只需要在每一个scanf_s语句后面加一个getchar()语句吞噬掉换行符即可。不太了解缓存区、getchar()的可以去查一下。
5、黑窗口出现“烫烫烫烫烫……”
要求输入的类型和实际输入的类型不一样就会出现“烫烫烫烫烫……”
这是这两天做程序设计遇到的一些印象比较深的坑,如有错误欢迎指正。(´▽`)ノ