C++二維指標動態分配記憶體連續問題

來源:互聯網
上載者:User

當我們定義一個二維指標時,如果需要儲存相應的資料,就需要我們動態分配記憶體,這時,有一點是需 要注意的,分配記憶體的方法不同,記憶體的連續性也是不相同的,首先,博主先貼出測試代碼:

#include <cstdlib>  #include <iostream>        using namespace std;        #define nWidth  3  #define nHeight 4        //記憶體是否連續分配問題   int main(int argc, char *argv[])  {      int **p = NULL;      p = (int**)malloc(nWidth*sizeof(int*));      if(p == NULL)      return -1;                cout<<"記憶體的不連續分配:"<<endl;      for(int j = 0; j< nWidth; j++)      {         p[j] = (int*)malloc(nHeight*sizeof(int));         if(p[j] == NULL)         return -1;      }                for(int i = 0; i < nWidth; i++)          for(int j = 0; j < nHeight; j++)          {              printf("%p  ",&p[i][j]);              if(j == nHeight-1)                  cout<<endl;          }      cout<<endl;                for(int j = 0; j < nWidth; j++)      {         free(p[j]);         p[j] = NULL;              }      free(p);      p = NULL;                          int **q = NULL;      q = (int**)malloc(nWidth*sizeof(int*));      if(q == NULL)      return -1;                cout<<"記憶體的連續分配:"<<endl;      q[0] = (int*)malloc(nWidth*nHeight*sizeof(int));      if(q[0] == NULL)      {          free(q);          return -1;      }      for(int i = 1;i < nWidth; i++)      q[i] = q[i-1] + nHeight;                for(int i = 0; i < nWidth; i++)          for(int j = 0; j < nHeight; j++)          {              printf("%p  ",&q[i][j]);              if(j == nHeight-1)                  cout<<endl;          }      cout<<endl;                free(q[0]);      q[0] = NULL;      free(q);      q = NULL;                system("PAUSE");      return EXIT_SUCCESS;  }

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.