WHCSRL 技术网

scanf与scanf

1.scanf_s(是vs提供的函数)

a.代码1

  1. int main()
  2. {
  3. char a = 0;
  4. //scanf_s("%%%%c", &a, 1);
  5. scanf_s("%%%%c", &a, sizeof(a));
  6. return 0;
  7. }

scanf_s有三个参数,最后一个是变量a所占据空间的大小(单位为字节),这里可以写1,也可以写sizeof(a)。如果a为整型的话,第三个参数就为4,或者sizeof(a)。

b.代码2

  1. int main()
  2. {
  3. char a = 0, b = 0;
  4. scanf_s("%%%%c %%%%c", &a, 1, &b, 1);
  5. printf("%%%%c %%%%c", a, b);
  6. return 0;
  7. }

可不要写成  scanf_s("%%%%c%%%%c",&a,&b,1,1); 这样会出错的

c.代码3

  1. int main()
  2. {
  3. char arr1[5] = { 0 };
  4. scanf_s("%%%%s", arr1, sizeof(arr1));
  5. printf("%%%%s", arr1);
  6. return 0;
  7. }

注意:输入字符的个数时,一定是比数组的空间个数小的,比如像上面的代码只能输入1-4个字符,而不是5个,不然会出错的。(arr[4]装的是一个'',字符串结束标志)

d.代码4

  1. int main()
  2. {
  3. int a[5] = { 0 };
  4. for (int i = 0; i < 5; i++)
  5. {
  6. scanf_s("%%%%d", &a[i], sizeof(a[i]));
  7. }
  8. for (int i = 0; i < 5; i++)
  9. {
  10. printf(" %%%%d", a[i]);
  11. }
  12. return 0;
  13. }

注意一点的是 那个取地址符(&)不要忘写了。

e.安全性检测

  1. int main()
  2. {
  3. char arr1[5] = { 0 };
  4. int c=scanf_s("%%%%s", arr1, sizeof(arr1));
  5. printf("%%%%d ", c);
  6. printf("%%%%s", arr1);
  7. return 0;
  8. }

如果输入的字符个数>=数组空间 个数,scanf_s的返回值就为0,反之则为1。

  1. int main()
  2. {
  3. char arr1[5] = { 0 };
  4. scanf_s("%%%%s", arr1, sizeof(arr1));
  5. printf("%%%%s", arr1);
  6. return 0;
  7. }

 如果输入的字符个数>=数组空间 个数,是不会打印数组中的元素的。(而scanf函数就会打印出)

2.scanf(标准的库函数)

a.代码1

  1. #define _CRT_SECURE_NO_WARNINGS
  2. #include <stdio.h>
  3. int main()
  4. {
  5. int a = 0;
  6. scanf("%%%%d", &a);
  7. printf("%%%%d", a);
  8. return 0;
  9. }

在VS13 17 19的版本下使用scanf函数一定在最开始(#define _CRT_SECURE_NO_WARNINGS

),不然会报错的。

b.安全性测试

  1. int main()
  2. {
  3. char arr1[5] = { 0 };
  4. int c=scanf("%%%%s", arr1);
  5. printf("%%%%d ", c);
  6. printf("%%%%s", arr1);
  7. return 0;
  8. }

 当我们输入abcdefg 7个字符时(已经超出了数组的空间个数了),虽然可以打印出来,但是arr1附近的栈空间已被破坏了,出现越界的情况了。scanf_s不会打印出来,也就不存在越界的行为了。

c.当在scanf函数里面输入格式符

如%%%%d %%%%d(%%%%d%%%%d之间有空格),那么通过标准输入设备(键盘)输入时两个整型之间也加一个空格。

如%%%%d,%%%%d(%%%%d%%%%d之间逗号),那么通过标准输入设备(键盘)输入时两个整型之间也加一个逗号。

3.总结

使用scanf_s函数虽然安全性比较高,但是可移植性差。比如含有scanf_s函数的代码不一定在其它的编译器上能够跑过。

scanf函数虽然没有scanf_s函数那么安全,但可移植性是比scanf_s强。

  scanf_s函数与scanf函数的使用与比较今天就分享到这里了,如果对你有帮助的话吗,可以给个关注,顺便给个赞。

推荐阅读