解決c++?error:crosses?initialization?of?問題
最近在寫代碼的時候,碰到了 crosses initialization of ...
的問題,只因我在 switch 的某個 case 分支下定義了一個變量,于是乎便將這個問題整理一下。
情形1 在 switch case 的某個分支定義了變量
1.1 問題代碼示例
#include <iostream> void switchTest(int code); int main() { switchTest(1); } void switchTest(int code) { switch (code) { case 1: int myNum = 0; break; case 2: break; default: break; } }
上述代碼,我在第一個 case 分支下定義了 myNum 變量,嘗試編譯,出現(xiàn)如下錯誤。主要看 C2360 這一行,myNum 的初始化操作由 case標簽跳過
,也就是說當 code !=1
的時候,不會進行 myNum 的初始化。第一反應是“我這個 myNum 只在 case 1 下用啊,不初始化就不初始化嘛,反正其他地方又不用”。
呃,這就牽扯到變量的作用范圍了。myNum 這個局部變量的作用范圍是從定義處開始直到 switch 語句結束。通俗說,就算我們跳過了 case 1 處的初始化,myNum 在后面的分支中,也是可以被訪問到的,被訪問到就有可能被使用(雖然我們自己沒打算在后面使用,但編譯器認為這是有風險的),但是我們又沒有對其進行初始化,那這就會出問題
。那這個問題怎么處理呢?
1.2 問題的解決
1.2.1 限定 myNum 的作用域
void switchTest(int code) { switch (code) { case 1: { int myNum = 0; break; } case 2: break; default: break; } }
我們給 case 1 加上大括號,明確告訴編譯器,我們在后面不使用這個 myNum 了,它只在 case 1 里有效,這種方式應該是最符合我們本意的。
1.2.2 確保 myNun 被初始化
void switchTest(int code) { int myNum = 0; switch (code) { case 1: break; case 2: break; default: break; } }
既然 myNum 不被初始化的原因的是 case 分支,那么我們將 myNum 的初始化提到 switch 外面吧,這樣一來,在它的作用域內,myNum 就肯定會被初始化了。
1.2.3 不算方案的方案
void switchTest(int code) { switch (code) { case 2: break; case 1: int myNum = 0; break; } }
上面這種寫法是能編譯過的,而且滿足我的意圖。我把 case 1 放到了最后一個分支,這樣一來,myNum 的作用域就只是在最后一個分支了,在 myNum 的作用域內,它都是被初始化了的
,因此是不會出問題的。當然,這樣寫只是為了說明,出現(xiàn)這個錯誤的根因是:變量在其作用范圍內,可能不會被初始化
。(項目中請勿這樣弄哦)
情形2 goto 跳過了變量的初始化
2.1 goto 中的錯誤示例
#include <iostream> void gotoTest(); int main() { gotoTest(); } void gotoTest() { goto label; int myNum = 1; label: std::cout << "goto the label" << std::endl; }
上面的代碼里,我們使用 goto 跳過了 myNum 的初始化,不出意外的出了意外,編譯時出現(xiàn)如下錯誤,原因和我們上面 switch 的例子是一樣的,那解決方法自熱也是類似的
2.2 問題的解決
2.2.1 限定 myNum 的作用域
void gotoTest() { goto label; { int myNum = 1; } label: std::cout << "goto the label" << std::endl; }
限制 myNum 的作用域,告訴編譯器我們在后面不使用了。
2.2.2 確保 myNun 被初始化
void gotoTest() { int myNum = 1; goto label; label: std::cout << "goto the label" << std::endl; }
將 myNum 的初始化提前,確保不會因為 goto 導致跳過了初始化。
結論
crosses initialization of
翻譯過來就是 跳過了初始化
,根本原因是變量在其作用范圍內,存在不被初始化的風險,解決思路有兩個:一是明確限定變量的作用域;而是將初始化提前,避免不被初始化的發(fā)生。
到此這篇關于解決c++ error:crosses initialization of 問題的文章就介紹到這了,更多相關c++ crosses initialization of內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- c++?error:crosses?initialization?of問題解決分析
- 詳解C/C++ Linux出錯處理函數(shù)(strerror與perror)的使用
- 關于VS2019 C++項目同時出現(xiàn)LNK2005 和LNK1169 error 的解決辦法
- 解決啟動MongoDB錯誤:error while loading shared libraries: libstdc++.so.6:cannot open shared object file:
- 解決VC++編譯報錯error C2248的方案
- c++ mk文件出錯Jni調用產生java.lang.UnsatisfiedLinkError錯誤解決方法
- c/c++?Error:?redefinition?of?'xxx'的問題及解決方法
相關文章
C++中的new/delete、構造/析構函數(shù)、dynamic_cast分析
這篇文章主要介紹了C++中的new/delete、構造/析構函數(shù)、dynamic_cast分析 本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05