標籤:
原文地址:http://www.cnblogs.com/gb2013/archive/2013/03/05/SecurityEnhancementsInTheCRT.html
在VS 2012 中編譯 C 語言項目,如果使用了 scanf 函數,編譯時間便會提示如下錯誤:
error C4996: ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
原因是Visual C++ 2012 使用了更加安全的 run-time library routines 。新的Security CRT functions(就是那些帶有“_s”尾碼的函數),請參見:
《CRT函數的安全增強版本》
下面給出這個問題的解決方案:
方法一:將原來的舊函數替換成新的 Security CRT functions。
方法二:用以下方法屏蔽這個警告:
1. 在先行編譯標頭檔stdafx.h裡(注意:一定要在沒有include任何標頭檔之前)定義下面的宏:
#define _CRT_SECURE_NO_DEPRECATE
2. 或聲明 #param warning(disable:4996)
3. 更改預先處理定義:
項目->屬性->配置屬性->C/C++ -> 前置處理器 -> 前置處理器定義,增加:
_CRT_SECURE_NO_DEPRECATE
方法三:方法二沒有使用更加安全的 CRT 函數,顯然不是一個值得推薦的好方法,但我們又不想一個一個地改函數名,這裡還有一個更簡便的方法:
在先行編譯標頭檔 stdafx.h 裡(同樣要在沒有include任何標頭檔之前)定義下面的宏:
#define _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 1
在連結的時候便會自動將舊函數替換成 Security CRT functions 。
注意:這個方法雖然使用了新的函數,但是不能消除警告(原因見紅字),你還得同時使用方法二(-_-)。即實際應在先行編譯標頭檔 stdafx.h 裡加入下面兩句:
#define _CRT_SECURE_NO_DEPRECATE
#define _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 1
錯誤原因解釋:
這種微軟的警告,主要因為那些C庫的函數,很多函數內部是不進行參數檢測的(包括越界類的),微軟擔心使用這些會造成記憶體異常,所以就改寫了同樣功能的函數,改寫了的函數進行了參數的檢測,使用這些新的函數會更安全和便捷。關於這些改寫的函數你不用專門去記憶,因為編譯器對於每個函數在給出警告時,都會告訴你相應的安全函數,查看警告資訊就可以獲知,在使用時也再查看一下MSDN詳細瞭解。
參考資料:《安全模板重載》
[轉]Visual Studio 2012 編譯錯誤【error C4996: 'scanf': This function or variable may be unsafe. 】的解決方案