c++ 一块内存转为二维数组 因为需要连续内存,所以不用自带STL类,需要用到 ** 指针的指针。
使用std::malloc分配
#include <iostream>
#include <memory>
using namespace std;
int main(int argc, char** argv){
int n,j;
cin>>n>>j;
//输入二维数组行和列
if(n==0||j==0){
return 0;
}
//看下长度和内存地址长度,用下标模拟二维数组
cout<<"new size:"<<sizeof(int[n][j])<<" memony:"<<sizeof(int *)<<endl;
int **pp;//指针的指针,放内存地址的
//申请存放每行指针内存地址n表示有N个内存地址需要放
pp=(int**)std::malloc(sizeof(int *)*n);
if(!pp) {
return 0;
}
//申请边续内存地址块,放数值的int值,也可以别的固定长度字符什么的
*pp=(int*)std::malloc(sizeof(int[n][j]));
if(!*pp) {
return 0;
}
std::cout <<hex<<*pp<<endl;
for(int i=1; i<n; i++){
pp[i]=pp[i-1]+j;
//输出每行内存地址,第二维是用下标模拟访问
std::cout <<hex<<pp[i]<<endl;
}
//给内存块赋值 int型
int b=0;
for(int i=0; i<n; i++){
for(int m=0; m<j; m++){
pp[i][m]=i*j+m;
}
}
//输出值和内存地址
for(int i=0; i<n; i++){
for(int m=0; m<j; m++){
std::cout << "pp[" << i << "]["<<m<<"] == "<<hex <<pp[i][m]<<" addr:"<<hex<<&pp[i][m]<<endl;
}
}
std::free(pp[0]);
std::free(pp); return 0;
}
输入4 4
4 4
new size:64 memony:8
0x7fe476500020
0x7fe476500030
0x7fe476500040
0x7fe476500050
pp[0][0] == 0 addr:0x7fe476500020
pp[0][1] == 1 addr:0x7fe476500024
pp[0][2] == 2 addr:0x7fe476500028
pp[0][3] == 3 addr:0x7fe47650002c
pp[1][0] == 4 addr:0x7fe476500030
pp[1][1] == 5 addr:0x7fe476500034
pp[1][2] == 6 addr:0x7fe476500038
pp[1][3] == 7 addr:0x7fe47650003c
pp[2][0] == 8 addr:0x7fe476500040
pp[2][1] == 9 addr:0x7fe476500044
pp[2][2] == a addr:0x7fe476500048
pp[2][3] == b addr:0x7fe47650004c
pp[3][0] == c addr:0x7fe476500050
pp[3][1] == d addr:0x7fe476500054
pp[3][2] == e addr:0x7fe476500058
pp[3][3] == f addr:0x7fe47650005c