调试出错,求助:EXPRESSION:_BLOCK_TYPE_IS_VALID(pHead->nBlockUse )

luckyviolet07 2014-09-30 02:33:39

我的程序中调用了以下函数:
void fft(int fft_nLen, int fft_M,int isign)
{
int i;
int lev,dist,p,t;
complex B;

W = (complex *)malloc(complexsize*fft_nLen/2);

for(lev=1; lev<=fft_M; lev++)
{
dist = (int)pow(2.0,lev-1);
for(t=0; t<dist; t++)
{
p = isign*t*(int)pow(2.0,fft_M-lev);
W[p].real = (float)cos(2*PI*(p)/fft_nLen);
W[p].image = (float)(-1*sin(2*PI*(p)/fft_nLen));
for(i=t; i<fft_nLen; i=i+(int)pow(2.0,lev))
{
B = Add(A[i],Mul(A[i+dist],W[p]));
A[i+dist] = Sub(A[i],Mul(A[i+dist],W[p]));
A[i].real = B.real;
A[i].image = B.image;
}
}
}

free(W);
}
我在网上查到,出现这种问题一般都是同一个内存释放了两次,但是我的问题是,当isign设置为1的时候,程序运行正常,当isign设置为-1时才会报错。所以应该和内存重复释放没有关系。那么问题出现在哪里呢?

...全文
362 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
luckyviolet07 2014-09-30
  • 打赏
  • 举报
回复
引用 2 楼 jianwen0529 的回复:
p = isign*t*(int)pow(2.0,fft_M-lev); W[p].real = (float)cos(2*PI*(p)/fft_nLen); W[p].image = (float)(-1*sin(2*PI*(p)/fft_nLen)); isign = -1; p为负数,然后一个负数当做下标?!
汗,我只想着让isign=1时结果是cosx-sinx,等于-1时结果是cosx+sinx,结果忘了考虑下标的问题,改一下变量位置就对了,谢谢你啦
luckyviolet07 2014-09-30
  • 打赏
  • 举报
回复
引用 1 楼 xiaohuh421 的回复:
p = isign*t*(int)pow(2.0,fft_M-lev); 这里 isign为负的时候p计算来是否会为负数呢? W[p] 访问时是否会越界呢? 基本上是由于越界, 导致内存被破坏, 释放时就会出错.
谢谢啦,我刚刚修改了一下,把isign改到这个位置: W[p].image = (float)(isign*(-1*sin(2*PI*p/fft_nLen))); 果然运行出正确的结果了,之前的应该是数组下标越界
幻夢之葉 2014-09-30
  • 打赏
  • 举报
回复
p = isign*t*(int)pow(2.0,fft_M-lev); W[p].real = (float)cos(2*PI*(p)/fft_nLen); W[p].image = (float)(-1*sin(2*PI*(p)/fft_nLen)); isign = -1; p为负数,然后一个负数当做下标?!
xiaohuh421 2014-09-30
  • 打赏
  • 举报
回复
p = isign*t*(int)pow(2.0,fft_M-lev); 这里 isign为负的时候p计算来是否会为负数呢? W[p] 访问时是否会越界呢? 基本上是由于越界, 导致内存被破坏, 释放时就会出错.

64,646

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧