1. 程式人生 > >c++動態分配二維/三維陣列的記憶體

c++動態分配二維/三維陣列的記憶體

轉自http://blog.csdn.net/boylinux/article/details/7783871

本文主要目的是用c和c++分別實現動態分配二、三維陣列。一般而言,在C中用malloc和free實現,而在C++中用new和delete。 new和delete是c++操作符,malloc和free是c語言函式,它們都可以用來為物件動態分配空間,最大的區別在於:當用new和 delete為物件分配空間或delete物件時,將預設的呼叫物件的建構函式及析購函式,而malloc和free是原來c庫中的函式,顯然沒有這項功 能,因此,在c++中,最好使用new和delete。


動態分配二維陣列的程式

//////////////c用malloc和free//////////////////////////////
#include   "stdio.h"   
#include   "stdlib.h"   

void   main()   
{   
    
int **p;   
    
int i,j
//p[4][8] 
    //開始分配4行8列的二維資料   
    
= (int**)malloc(sizeof(int*)*4);   
    
for(i=0i<4i++)   
        
p[i] = (int*)malloc(sizeof(int)*8); 
    
    
for(i=0i<4i++)   
        
for
(j=0j<8j++)   
            
p[i][j] = j*i;   
        
//列印資料   
        
for(i=0i<4i++)   
            
for(j=0j<8j++)     
            {   
                
if(j==0printf("\n");   
                
printf("%3d",p[i][j]);   
            }   
            
//開始釋放申請的堆   
            
for(i=0i
<4i++)   
                
free(p[i]);   
            
free(p);  
            
}
///////////////////////////////////////////////////////////

//////////////c++用new和delete/////////////////////////////
#include <iostream>
using namespace std;   

void main()   
{   
    
int **p;   
    
int i,j;   
//p[4][8] 
    //開始分配4行8列的二維資料   
    
new int *[4];
    
for(i=0;i<4;i++)
        
p[i]=new int [8];
    
    
for(i=0i<4i++)   
        
for(j=0j<8j++)   
            
p[i][j] = j*i;   
        
//列印資料   
        
for(i=0i<4i++)   
            
for(j=0j<8j++)     
            {   
                
if(j==0cout<<endl;   
                
cout<<p[i][j]<<"\t";   
            }   
            
//開始釋放申請的堆   
            
for(i=0i<4i++)   
                
delete [] p[i];   
            
delete [] p;   
}
///////////////////////////////////////////////////////////


動態分配三維陣列的程式
//////////////c用malloc和free//////////////////////////////
#include   "stdlib.h"   
#include   "stdio.h"   

void main()   
{   
    
int i,j,k;   
//p[2][3][4]
    
    
char ***= (char***)malloc(2sizeof(char**));   
    
for(i=0i<2i++)   
    {     
        
p[i] = (char**)malloc(3*sizeof(char*));   
        
for(j=0j<3j++)   
        {   
            
p[i][j] = (char*)malloc(4*sizeof(char));   
        }   
    }
    
    
//finish creating use p[i][j][k] to access the data   
    
for(i=0i<2i++)   
    {
        
for(j=0j<3j++)   
        { 
            
for(k=0;k<4;k++)
            { 
                
p[i][j][k]=i+j+k;
                
printf("%d ",p[i][j][k]);
            }
            
printf("\n");
        }
        
printf("\n");
    }
    
    
//free the memory   
    
for(i=0i<2i++) 
    {
        
for(j=0j<3j++) 
        {   
            
free(p[i][j]);   
        }   
    }       
    
for(i=0i<2i++)   
    {       
        
free(p[i]);   
    }   
    
free(p);  
    

///////////////////////////////////////////////////////////


//////////////c++用new和delete/////////////////////////////
#include <iostream>
using namespace std;   

void main()   
{   
    
int i,j,k;   
// p[2][3][4]
    
    
int ***p;
    
new int **[2]; 
    
for(i=0i<2i++) 
    { 
        
p[i]=new int *[3]; 
        
for(j=0j<3j++) 
            
p[i][j]=new int[4]; 
    }
    
    
//finish creating use p[i][j][k] to access the data   
    
for(i=0i<2i++)   
    {
        
for(j=0j<3j++)   
        { 
            
for(k=0;k<4;k++)
            { 
                
p[i][j][k]=i+j+k;
                
cout<<p[i][j][k]<<" ";
            }
            
cout<<endl;
        }
        
cout<<endl;
    }
    
    
//free the memory   
    
for(i=0i<2i++) 
    {
        
for(j=0j<3j++) 
        {   
            
delete [] p[i][j];   
        }   
    }       
    
for(i=0i<2i++)   
    {       
        
delete [] p[i];   
    }   
    
delete [] p;  
    

///////////////////////////////////////////////////////////c和c++分別實現動態分配二、三維陣列(轉)