gpt4 book ai didi

C++ 索引变量在调试版本中发生根本性变化

转载 作者:行者123 更新时间:2023-11-30 21:18:47 25 4
gpt4 key购买 nike

我发现了很多与发行版本问题有关的答案,但没有一个答案完全相反。

我有一个类似于以下内容的循环:

while(index < 7 && FlagIsUp)
{
// process
Inner Loop
Inner Inner Loop
Array[index] = number;
++index;
}

问题是 int16_t 的索引从 6(最后一次迭代)急剧变化为 17209,size_t 的索引从 1133165442 急剧变化。除了++index 之外,循环中的任何内容都不会更改索引。我用 for 替换了 while,但它仍然发生。

它只发生在 Debug模式下,在发布版本中它确实完成而没有问题。

我还在索引中添加了 volatile,结果是一样的,但仍然溢出。

任何想法、指点,我们将不胜感激。我无法提供该错误的工作拷贝,因此欢迎任何理论,我想用尽我的选择来找到问题。

编辑:是的,我很抱歉。我提供的信息很少。首先,我使用的是 QNX Momentics 版本:4.6.0,我的调试器是 GNU 编译器集合 4.3.3 的一部分。

现在内部循环是这样的:

cSignalNoIndex = 0;
while ((cSignalNoIndex < (2 * NO_PHASES + 1)) && !ShutDownFlag)
{
wSF0 = 0;
wExtSF = 0;
dwSFAcc = 0;
dwExtSFAcc = 0;
std::string SignalNo= " Waveform number " + Tool::toString(cSignalNoIndex);
Results[cSignalNoIndex].printWaveForm(SignalNo);
// Prepare Input vectors for FFT compute
cComponent = 0;
while (cComponent < (HCYCLE_SAMPLES << 1))
{
awReal[cComponent] = static_cast<int>(Results[cSignalNoIndex].WaveForm[cComponent/64][cComponent % 64]);
awImg[cComponent] = 0;
pwSource++;
cComponent++;
}
Results[cSignalNoIndex].printWaveForm(SignalNo);
// Get FFT (forward)
// Changed the wPwr from 7 to something else
iFft(&awReal[0], &awImg[0], wPwr, 1);
Results[cSignalNoIndex].printWaveForm(SignalNo);
// Compute magnitudes
//fMult = pInBlock3->fMult[cSignalNoIndex]; // Get Multiplier
fMult = 1;
for (cComponent = 0; cComponent < HCYCLE_SAMPLES && !ShutDownFlag; cComponent++)
{
int64_t dlOp = static_cast<int64_t>(awReal[cComponent]) * awReal[cComponent] + static_cast<int64_t>(awImg[cComponent]) * awImg[cComponent];
dlOp <<= 1; // Apply sqrt(2) term to result
dlOp = static_cast<int>(fMult * isqrt64(dlOp));

// Store into FFT object
oFFTMag3.wFFT[cSignalNoIndex][cComponent] = static_cast<int16_t>( dlOp );

// Set Base frequency magnitude and accumulate harmonics
if (cComponent == 1) // Base
{
wSF0 = dlOp;

if(cSignalNoIndex == 6)
{
wRefMagnitude = static_cast<int16_t> ( 0.4 * wSF0 );
}

if(awReal[1] != 0) // Also get phase for Base
{
dfPhase = std::atan((double)((float)awImg[1]/awReal[1])) * 180.0 / PI;
}
else
{
if(awImg[1] >= 0)
{
dfPhase = 90.0;
}
else
{
dfPhase = -90.0;
}
}

if(awReal[1] < 0) // convert to 2*PI range
{
dfPhase += 180.0;
}
else if(awImg[1] < 0)
{
dfPhase += 360.0;
}
//// THIS IS THE LINE
fPhase[cSignalNoIndex] = dfPhase; ////////// WTF! cSignalNoIndex = 6 - cComponent = 2
/// HERE cSignalNoIndex is overflown
}
}

最佳答案

您还没有真正发布足够的代码,但我最好的选择是Array[index] = number在某个时候覆盖index。事实上,它仅有时发生(在您的情况下,在调试时)是“未定义行为”的一个很好的例子。

关于C++ 索引变量在调试版本中发生根本性变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15207408/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com