1

我有一个名为 的 C 函数from_binary_to_decimal,它被另一个函数调用x_caching。问题是from_binary_to_decimal返回例如 2.25 (一个浮点数)但是x_caching(写了一行来存储返回值)修改了第一个函数返回的前一个值。

我放置了代码的图像(按照它们的执行顺序):

float** cache_provider(struct INPUT_DATA* d, char** arrszChromosomes)
{
    static float** arrfCache = NULL;
    int i;
    if (d == NULL && arrszChromosomes == NULL) return arrfCache;

    if (arrfCache == NULL)
    {
        arrfCache = (float**)malloc(d->m_iPopulationSize * sizeof(float*));
        for (i = 0; i < d->m_iPopulationSize; ++i)
        arrfCache[i] = (float*)malloc(2 * sizeof(float));
    }

    x_caching(d, arrszChromosomes, &arrfCache);

    return arrfCache;

}

void x_caching(struct INPUT_DATA *d,
               char **arrszChromosomes,
               float **arrfCache)
{  
    int i;
    float fTemp = 0.0f;

    for (i = 0; i < d->m_iPopulationSize; ++i) {
        arrfCache[i][0] = get_cache_key(arrszChromosomes[i]);
        fTemp = from_binary_to_decimal(d, arrszChromosomes[i], 0);
        arrfCache[i][1] = fTemp;
    }
}

float from_binary_to_decimal(struct INPUT_DATA *d,
                             char *szChromosome,
                             int iCacheQuery)
{  
    float fRetVal = 0.0;
    float fFinal = 0.0f;
    float *fCacheVal = NULL;
    int i = 0;

    if (iCacheQuery
        && (fCacheVal = get_x_value_from_cache(szChromosome)) != NULL)
        return *fCacheVal;

    for (i = 0; i < strlen(szChromosome); ++i)
        fRetVal +=
            (szChromosome[i] == '1' ? 1 : 0) *
            powf(2, d->m_iBitsPChromosome - (i + 1));

    fFinal = d->m_arrcDomainInterval[0] + (fRetVal * d->m_fDelta);
    return fFinal;
}

fTemp应该存储像 2.51 这样的数字,而不是存储像 8133608 这样的值。

4

2 回答 2

3

对于初学者,您分配的浮点数组的数量以及用于访问它们的数组索引是不同的:

arrfCache = (float**)malloc(d->m_iMaxGenerations * sizeof(float*));
for (i = 0; i < d->m_iPopulationSize; ++i)
    arrfCache[i] = (float*)malloc(2 * sizeof(float));

您已经分配了d->m_iMaxGenerations浮点数组,但您正在遍历d->m_iPopulationSize它们。

for您拥有的循环相同fTemp

for (i = 0; i < d->m_iPopulationSize; ++i)

当您只分配arrfCache. 如果更小,这可能会导致内存损坏和奇怪的值,如您所见。d->m_iPopulationSized->m_iMaxGenerationsd->m_iMaxGenerations

于 2013-03-14T19:10:25.717 回答
3

您永远不会设置arrfCache为非空值。此外, x_caching 应该具有以下形式的声明:

void x_caching (struct INPUT_DATA* d, char** arrszChromosomes, float*** arrfCache)

因为您希望 arrfCache 成为输出参数。

x_caching(d, arrszChromosomes, &arrfTempCache);
...
*arrfCache = malloc(....)
....
(*arrfCache)[i][0] = ...
于 2013-03-14T19:12:14.903 回答