我跑了一百万次循环.在循环中,我调用C函数进行一些数学运算(确切地说,从各种分布生成随机变量).作为该函数的一部分,我声明了几个双变量来保存转换的一部分.一个例子: void getRan
void getRandNorm(double *randnorm, double mean, double var, int n)
{
// Declare variables
double u1;
double u2;
int arrptr = 0;
double sigma = sqrt(var); // the standard deviation
while (arrptr < n) {
// Generate two uniform random variables
u1 = rand() / (double)RAND_MAX;
u2 = rand() / (double)RAND_MAX;
// Box-Muller transform
randnorm[arrptr] = sqrt(-2*log(u1))*cos(2*pi*u2)*sigma+mean;
arrptr++;
if (arrptr < n) { // for an odd n, we cannot add off the end
randnorm[arrptr] = sqrt(-2*log(u2))*cos(2*pi*u1)*sigma+mean;
arrptr++;
}
}
}
和调用循环:
iter = 1000000 // or something
for (i = 0; i < iter; i++) {
// lots of if statements
getRandNorm(sample1, truemean1, truevar1, n);
// some more analysis
}
我正在加快运行时间.在我看来,我不知道我声明的所有这些双变量发生了什么.我假设为一百万个循环中的每个循环分配一个新的8字节内存块用于double.所有这些内存位置会发生什么?它们在C函数中声明;他们能活下来吗?在脚本退出之前,它们是否仍处于锁定状态?
这个问题的上下文是将这个C程序包装成python函数.如果我要从python并行多次执行这个函数,我想确保我尽可能节省内存.
如果你在谈论这样的事情:for(int i=0;i<100000;i++){
double d = 5;
// some other stuff here
}
d仅由编译器分配一次.它主要等同于在for循环之上声明它,除了范围没有延伸到目前为止.
但是,如果您正在执行以下操作:
for(int i=0;i<1000000;i++){
double *d = malloc(sizeof(double));
free(d);
}
然后是的,你将分配一倍的双倍,但它可能会重新使用内存进行后续分配.最后,如果你在我的第二个例子中没有释放内存,你将泄漏16-32MB的内存.
