vs的【warning C4996:'fopen': This function or variable may be unsafe】解決方案


轉載自:http://my.oschina.net/liujinofhome/blog/36287 以及http://blog.sina.com.cn/s/blog_562f523f0100rezj.html

二、編譯警告:warning C4996 與 Security Enhancements in the CRT

將過去的工程用VS2005打開的時候。你有可能會遇到一大堆的警告:warning C4996。
比如:
warning C4996: 'strcpy': This function or variable may be unsafe. Consider using strcpy_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
1>          c:\program files\microsoft visual studio 10.0\vc\include\string.h(105) : 參見“strcpy”的聲明

warning C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
1>          c:\program files\microsoft visual studio 10.0\vc\include\stdio.h(234) : 參見“fopen”的聲明

原因是Visual C++ 2005使用了更加安全的run-time library routines。
新的Security CRT functions(就是那些帶有“_s”後綴的函數):
http://msdn2.microsoft.com/en-us/library/wd3wzwts(VS.80).aspx

那麼如何搞定這些警告呢:
方法一:將原來的舊函數替換成新的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。
注意:這個方法雖然使用了新的函數,但是不能消除警告(原因見紅字),你還得同時使用方法二。。。

三、link error 1104
原因:當從vc6移植到.net時,會導致這個鏈接錯誤!
解決:項目屬性->配置屬性->鏈接器->輸入->忽略特定庫,加入libcd.lib;或直接在命令行中加入: /nodefaultlib:"libcd.lib"
注意:是否是libcd.lib,與C/C++屬性中的“代碼生成”選項相關

參考:
Security Enhancements in the CRT :
http://msdn2.microsoft.com/en-us/library/8ef0s5kh(VS.80).aspx
Secure Template Overloads :
http://msdn2.microsoft.com/en-us/library/ms175759(VS.80).aspx

==========================================================================

原因解釋
這種微軟的警告,主要因爲那些C庫的函數,很多函數內部是不進行參數檢測的(包括越界類的),微軟擔心使用這些會造成內存異常,所以就改寫了同樣功能的函數,改寫了的函數進行了參數的檢測,使用這些新的函數會更安全和便捷。關於這些改寫的函數你不用專門去記憶,因爲編譯器對於每個函數在給出警告時,都會告訴你相應的安全函數,查看警告信息就可以獲知,在使用時也再查看一下MSDN詳細瞭解。庫函數改寫例子:
mkdir改寫爲 _mkdir 
fopen”改寫爲 fopen_s 
stricmp改寫爲 stricmp_s
strcpy改寫爲strcpy_s

    解決方案:
1> 根據下面的warning提示:參見“fopen”的聲明
        消息:“This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_DEPRECATE. See online help for details.”
        所以可以將函數按warning提示的第二句,改爲使用fopen_s函數即可:
        例如:FILE *pFile=fopen("1.txt", "w");
           改爲:
           FILE* pFile;
           fopen_s(&pFile, "1.txt", "w"); 
2> 還是根據warning提示的地三句話:use _CRT_SECURE_NO_DEPRECATE
        項目|屬性|配置屬性|C/C++|命令行|附加選項,加入【/D "_CRT_SECURE_NO_DEPRECATE" 】(注:加入中括號中完整的內容)
3> 降低警告級別:項目|屬性|配置屬性|C/C++|常規,自己根據情況降低警告級別(此法不推薦)


    注意:高度重視警告:使用編譯器的最高警告級別。應該要求構建是乾淨利落的(沒有警告)。理解所有警告。通過 修改代碼而不是降低警告級別來排除警告。
    編譯器是你的朋友。如果它對某個構造發出警告,這經常是說明你的代碼中存在潛在的問題。成功的構建應該是無聲無息的(沒有警告的)。【《C++編程規 範》】

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章