[問題] 如何正確修正 warning C6011 ?
開發平台(Platform): (Ex: Win10, Linux, ...)
Windows 10 or 7
編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
Visual Studio Professional 2017 15.5.7
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
無,但是有啟動建置時啟用程式碼分析。
問題(Question):
已經寫了 null 指標檢查還是無法通過程式碼分析,
後來亂試試到一個騙過編譯器的方法如方法二,但是還是覺得這樣騙很不直覺。
想請問關於這個案例如何正確的解決C6011的改法。
餵入的資料(Input):
無。
預期的正確結果(Expected Output):
編譯成功,無警告。
錯誤結果(Wrong Output):
warning C6011: 正在取值 NULL 指標 'Ptr'。
程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔)
#include <iostream>
static inline void *DummyPointerConvert (void *Ptr)
{
return Ptr;
}
#define WA_C6011(type,pointer) ((type *)(DummyPointerConvert (pointer)))
void Func()
{
for (uint8_t *Ptr = (uint8_t *) ( (long) 0xFE000);
Ptr < (uint8_t *) ( (long) 0x100000);
Ptr += 0x10) {
if ( (Ptr != NULL) && ( (* (uint32_t *) Ptr) == 0)) { // warning C6011
break;
}
if (*WA_C6011(uint32_t, Ptr) == 0) { // OK
break;
}
}
}
int main()
{
return 0;
}
補充說明(Supplement):
無。
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 106.1.10.98
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1532873922.A.345.html
推
07/29 22:56,
7年前
, 1F
07/29 22:56, 1F
→
07/29 22:59,
7年前
, 2F
07/29 22:59, 2F
→
07/29 23:01,
7年前
, 3F
07/29 23:01, 3F
推
07/30 05:19,
7年前
, 4F
07/30 05:19, 4F
→
07/30 05:25,
7年前
, 5F
07/30 05:25, 5F
→
07/30 05:25,
7年前
, 6F
07/30 05:25, 6F
→
07/30 05:26,
7年前
, 7F
07/30 05:26, 7F
→
07/30 05:32,
7年前
, 8F
07/30 05:32, 8F
→
07/30 05:32,
7年前
, 9F
07/30 05:32, 9F
→
07/30 05:34,
7年前
, 10F
07/30 05:34, 10F
→
07/30 05:35,
7年前
, 11F
07/30 05:35, 11F
1. 因為我寫iostream 害各位認為我在寫C++ 我在此更正為C, 是程式碼移植的失誤 抱歉
2. 我已經拆成巢狀 VS的程式碼分析還是報 C6011 在該位置
#include <stdint.h>
void Func()
{
for (uint8_t *Ptr = (uint8_t *) ( (long) 0xFE000);
Ptr < (uint8_t *) ( (long) 0x100000);
Ptr += 0x10) {
if (Ptr != nullptr) {
if ( (* (uint32_t *) Ptr) == 0) { // warning C6011
break;
}
}
}
}
int main()
{
return 0;
}
※ 編輯: chrisdar (106.1.10.98), 07/30/2018 05:48:04
→
07/30 06:10,
7年前
, 12F
07/30 06:10, 12F
→
07/30 06:10,
7年前
, 13F
07/30 06:10, 13F
→
07/30 06:12,
7年前
, 14F
07/30 06:12, 14F
→
07/30 06:13,
7年前
, 15F
07/30 06:13, 15F
→
07/30 06:15,
7年前
, 16F
07/30 06:15, 16F
→
07/30 06:15,
7年前
, 17F
07/30 06:15, 17F
→
07/30 06:33,
7年前
, 18F
07/30 06:33, 18F
→
07/30 08:36,
7年前
, 19F
07/30 08:36, 19F
→
07/30 10:09,
7年前
, 20F
07/30 10:09, 20F
→
07/30 10:11,
7年前
, 21F
07/30 10:11, 21F
→
07/30 10:13,
7年前
, 22F
07/30 10:13, 22F
→
07/30 10:20,
7年前
, 23F
07/30 10:20, 23F
→
07/30 10:21,
7年前
, 24F
07/30 10:21, 24F
證實網友的看法:
#include <stdint.h>
void Func()
{
for (uint8_t *Ptr = (uint8_t *) ( (long) 0xFE000);
#if 1
true;
#else
Ptr < (uint8_t *) ( (long) 0x100000);
#endif
Ptr += 0x10) {
if ( (Ptr != nullptr) && (*Ptr == 0)) { // ok, 如果#if 0 C6011又出來
break;
}
}
}
int main()
{
return 0;
}
※ 編輯: chrisdar (106.1.10.98), 07/30/2018 20:15:44
另外一種騙法 給各位參考
#include <stdint.h>
static inline void *DummyPointerConvert (void *Ptr)
{
return Ptr;
}
#define WA_C6011(type,pointer) \
((type *)(DummyPointerConvert ((void *)(pointer))))
void Func()
{
for (uint8_t *Ptr = (uint8_t *) ( (long) 0xFE000);
Ptr < WA_C6011 (uint8_t, 0x100000);
Ptr += 0x10) {
if ( (Ptr != nullptr) && (*Ptr == 0)) { // OK
break;
}
}
}
int main()
{
return 0;
}
※ 編輯: chrisdar (106.1.10.98), 07/30/2018 20:21:24
※ 編輯: chrisdar (106.1.10.98), 07/30/2018 20:24:17
推
07/30 22:40,
7年前
, 25F
07/30 22:40, 25F