關於C++ 動態定義數組


首先:為什么需要動態定義數組呢?
  這是因為,很多情況下,在預編譯過程階段,數組的長度是不能預先知道的,必須在程序運行時動態的給出
  但是問題是,c++要求定義數組時,必須明確給定數組的大小,要不然編譯通不過 
 
  如: int Array[5];正確

       int i=5;
       int Array[i]; 錯誤 因為在編譯階段,編譯器並不知道 i 的值是多少

   那么,我們該如何解決定義長度未知的數組呢?
   答案是:new 動態定義數組 

   因為new 就是用來動態開辟空間的,所以當然可以用來開辟一個數組空間
   
   這樣,下面的語句:
    int size=50;
    int *p=new int[size]; 是正確的
 
   但是二維動態數組能不能也這樣定義呢
   
  int size=50,Column=50;
  int (*p)[Column]=new int [size][Column]

  這樣的語句,編譯器通不過,為什么呢?
  首先 new int[size][Column] 就是動態生成時確定的,所以它沒有錯
  那么就是 int(*p)[Column],這句有問題了,這句為什么不對呢, 那是因為,這是一個定義語句,而定義語句先經過編譯器進行編譯,當編譯器運行到此處時,發現Column 不是常數,因此不能通過編譯。 而之所以編譯器認為Column 不是常數,是因為編譯階段,編譯器起的作用是查語法錯誤,和預分配空間,它並不執行程序,因此,沒有執行那個賦值語句(只是對這個語句檢查錯誤,和分配空間),因此編譯階段,它將認為column 是個變量。所以上面的二維數組定義是錯誤的, 它不能通過編譯。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM