在我的函数体reduce()
和initialize(...)
中,我希望将数组globalArray
用作三维数组,其中维度在运行时才会知道。
如何将globalArray
指针强制转换为可变长度数组(指针)并自然地使用它?
我认为typedef
方法有帮助,但我仍然输了。这个当前版本编译并且看起来在我的修修补补之后起作用。 Cast#1和Cast#2是否可以实现清晰和安全?
#include <stdlib.h>
#include <stdio.h>
double * globalArray; /* working from a situation where the array is global, declared elsewhere */
int M, N, P; /*array dimensions not known until runtime */
double reduce();
double reduce()
{
/* Here I want to re-interpret the one-dimensional globalArray into
a multi-dimensional variable-length array so that compiler takes
care of the indexing math for me.*/
typedef double (*arr_t)[N][P];
const arr_t castArray = (arr_t)globalArray; /* Cast #1 */
double sum=0.0;
for (int i=0; i<M; i++)
for (int j=0; j<N; j++)
for (int k=0; k<P; k++)
sum += castArray[i][j][k];
return sum;
}
void initialize(int M, int N, int P, double threedimarray[M][N][P])
{
for (int i=0; i<M; i++)
for (int j=0; j<N; j++)
for (int k=0; k<P; k++)
threedimarray[i][j][k] = (double)(i*N*P + j*P + k);
}
int main(int argc, char **argv)
{
M = 10; N=1000; P=200;
globalArray = malloc( M*N*P* sizeof(double) );
typedef double (*arr_t)[N][P];
initialize(M, N, P, (arr_t)globalArray); /* Cast #2 */
double result = reduce();
printf("Reduced result: %f\n", result );
return 0;
}
我正在修改一个大型程序的一小部分。显然有比程序范围数组指针更好的设计方法。就是这样。 从自我记录的角度来看,如果解决方案并没有抛弃我们已经知道的事实,那就很好了。&#34;领先维度(M)的范围。
与函数参数声明相关的类似SO问题是有帮助的,但我猜不是连接点。我决定在这里问,希望答案能够吸引更多人。
答案 0 :(得分:2)
这是我在经过一些修修补补后得出的一种可能的铸造解决方案。
typedef double (*arr_t)[N][P];
arr_t castArray = (arr_t)globalArray;
/* Now castArray can be accessed by multi-dimensional index notation */
castArray[i][j][k] = 3.14;
<强>缺点:强>
1)不会自我记录已知的前导尺寸长度M
。