用于调用的参数太少/写入位置时发生冲突/检测到无效的异常处理程序例程

用于调用的参数太少/写入位置时发生冲突/检测到无效的异常处理程序例程

针对新人学C过程中可能遇到的一类问题

我们在学习中经常遇到这种情况:

#include<stdio.h>
void main()
{
    
    
	char note[100] = "";
	scanf("%s", note, 100);//本行会报错提醒我们使用scanf_s代替scanf
}

很多带“_s”后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免引用到不存在的元素,有时黑客可以利用原版的不安全性黑掉系统。比如:char note[100];写成scanf_s("%s",note,100);或scanf_s("%s",note,sizeof(note));才是正确的,有这个参数100使准确性提高。

我列举了三个常见的异常

  • [ 1] 用于调用的参数太少
  • [ 2] 写入位置时发生冲突
  • [3 ] 检测到无效的异常处理程序例程

在处理这三个异常时可以观察代码是否有这样的错误:

//注释内是错误写法
scanf_s("%s", note,100);//缺少参数100 scanf_s("%s", note);

sprintf_s(temp, sizeof(temp) ,"\n收入\t%s\t\t%.2f\t\t%.2f", note, money, blance);
//缺失参数sizeof(temp)sprintf_s (temp, "\n收入\t%s\t\t%.2f\t\t%.2f", note, money, blance);

strcat_s(data,sizeof(data),temp);//同样缺失参数  strcat_s(data,temp);

希望对同为新手的你有所帮助。

猜你喜欢

转载自blog.csdn.net/Eric_xkk/article/details/108563892