在项目属性页-->配置属性-->C/C++-->预处理器-->预处理器定义 添加:_CRT_SECURE_NO_DEPRECATE程序员
注意:Debug和Release都要添加安全
微软解释说非安全库函数sprintf、sscanf、strcpy等都是不安全的,应该用sprintf_s、sscanf_s、strcpy_s取代函数
微软提出了以下10点建议:
1. 不要认为 strcpy_s 和 strncpy_s( 以及其余的字符串函数)(在空间不够的时候)会自动终止拷贝(truncate截断,不截断则意味着溢出).若是须要自动截断,请使用strncpy_s (同时使用_TRUNCATE做为长度参数)。
2. 记住fopen_s缺省是独占模式。如需共享使用文件,应该使用_sopen。
3. 别忘了_dupenv_s, 它将比_getenv_s更容易使用,由于它能自动分配一个正确长度的内存(buffer)。
4. 在scanf_s中当心参数顺序。
5. 肯定printf_s中格式字符串的正确。
6. 使用_countof(x)来取代sizeof(x)/sizeof(element). _countof将会正确的计算元素个数,并且若是x是一个指针,编译器将会发出一个警告(来提醒程序员,仅针对C++编译)
7. 记住全部的sizes(大小,非长度)都是使用characters(字符,unicode下一个字符占2个byte)做为单位,而不是bytes(字节).
8. 记住全部的sizes(大小,非长度,原因同上)包含了字符串结束符'\0'(即别忘了不少状况下size须要+1)。
9. 调试的时候监视数据0xfd。 (在调试版本下)0xfd将会被填充在数据(buffer,一般是字符串)的结尾处。若是运行非你所愿,可能会获得一个长度错误。
10. 检查全部的错误。 许多新函数相比旧函数,能返回(表示)错误信息(的数值)。spa