C :递归分配内存
C++: Allocation memory recursively?
double** ptr_d = new double*[2];
ptr_d[0] = new double[50];
ptr_d[1] = new double[50];
这实际上是什么?我有点困惑
这实际上是做什么的?
第一行创建了2个指针的数组来加倍。第二和第三行创建50个双打数组,并将指针分配给第一个元素,以2个指针数组元素:
{double *, double *} //2 pointers to double
| |
| V
| {double1, double2, ...double50} //50 doubles
|
V
{double1, double2, ...double50} //50 doubles
第一行将一组指针分配给2个 double
变量。接下来的2行填充了两个阵列插槽。如果它具有更好的命名:
double** temperatureValues = new double* [ 2 ];
temperatureValues [ 0 ] = new double [ 50 ];
temperatureValues [ 1 ] = new double [ 50 ];
或类似的东西。
您可以将其视为2 x 50值的2维数组。要访问您可以做的值之一:
double nextTemp = temperatureValues [ 0 ][ 32 ];
相关文章:
- Win32编译器选项和内存分配
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 当需要超过16GB的连续内存时,内存分配失败
- 尝试摆脱任何堆内存分配
- 以下代码执行哪种内存分配(动态或静态)?
- 开放 CV 中的动态内存分配,用于视频处理
- 为什么类和 main() 函数中也有动态内存分配
- 使用 NTAllocateVirtualMemory 和 GetProcAddress 的内存分配问题不起作用
- C++:矢量分配器行为、内存分配和智能指针
- 介于 [固定数组] 和 [带内存分配的指针] 之间的性能
- Linux C++ 中的页面对齐内存分配
- 整数内存分配/释放
- 将内存分配返回值强制转换为 TYPE 数组
- C++程序什么都不做,但瓦尔格林德显示内存分配
- 给定特定内存地址的数组的动态内存分配
- 如何完成内存分配
- 我刚刚了解了C++中的动态内存分配
- 在先前调用 string::find 后添加内存分配和内存集会导致它返回 npos.为什么?
- 对于堆上的页面对齐内存分配是否有任何优化或不同的 API?
- 无法删除布尔动态内存分配