動態記憶體空間的申請示範
利用C++的特性,能夠自定義空間的'型別大小和空間長度
下面這個程式是個陣列動態配置的簡單示例
複製程式碼 程式碼如下:
#include
using namespace std;
int main()
{ int size = 0;
cout << "請輸入陣列長度:"; //能夠自定義的動態申請空間長度
cin >> size;
int *arr_Point = new int[size];
cout << "指定元素值:" << endl;
for(int i = 0; i < size; i++)
{ cout << "arr[" << i << "] = ";
cin >> *(arr_Point+i);
}
cout << "顯示元素值:" << endl;
for(int i = 0; i < size; i++)
{ cout << "arr[" << i << "] = " << *(arr_Point+i)
<< endl;
}
[] arr_Point;
return 0;
}
執行結果:
複製程式碼 程式碼如下:
請輸入陣列長度:5
指定元素值:
arr[0] = 1
arr[1] = 2
arr[2] = 3
arr[3] = 4
arr[4] = 5
顯示元素值:
arr[0] = 1
arr[1] = 2
arr[2] = 3
arr[3] = 4
arr[4] = 5
可以使用指標來模擬二維陣列,只要清楚二維陣列中的兩個維度的索引值之位移量就可以
複製程式碼 程式碼如下:
#include
using namespace std;
int main()
{ int m = 0;
int n = 0;
cout << "輸入二維陣列維度:";
cin >> m >> n;
int *ptr = new int[m*n];
for(int i = 0; i < m; i++)
{ for(int j = 0; j < n; j++)
{ *(ptr + n*i + j) = i+j;
}
}
for(int i = 0; i < m; i++)
{ for(int j = 0; j < n; j++)
{ cout << *(ptr+n*i+j) << "t";
}
cout << endl;
}
[] ptr;
return 0;
}