![](/img/trans.png)
[英]Debug Assertion Failed … _BLOCK_TYPE_IS_VALID(pHead->nBlockUse)
[英]Debug Assertion Failed _BLOCK_TYPE_IS_VALID(pHead->nBlockUse)
我有这个问题:
调试断言失败!
文件:F:\\ DD \\ vctools \\ crt_bld \\ self_x86 \\ CRT \\ dbgdel.cpp
第52行
表达式“_BLOCK_TYPE_IS_VALID(pHead-> nBlockUse)
我的程序将所有值正确地返回到我期望的屏幕,但是这个问题让我很紧张......
#include <iostream>
#include <cstdlib>
#include <iomanip>
using namespace std;
double * wsk1;
double * wsk2;
double * wsk3;
double * kopiowanie(double *wsk1,double *wsk2, double *wsk3);
double * zaladuj(double *wsk1,double*wsk2);
int main()
{
wsk1 = new double [30]; // tak inicjalizuje sie dynamicznie tablice
wsk2 = new double [30];
wsk3= new double [30];
zaladuj(wsk1,wsk2);
kopiowanie(wsk1,wsk2,wsk3);
for (int i=0;i<30;i++)
{
cout << setw(10) << *wsk1 << setw(10) << *wsk2 << setw(10) << *wsk3 << endl;
wsk1++;
wsk2++;
wsk3++;
}
wsk1 -=29;
wsk2 -=29;
wsk3 -=29;
delete[] wsk1;
delete[] wsk2;
delete[] wsk3;
system("pause");
}
double * zaladuj(double * wsk1, double * wsk2)
{
for(int i=0;i < 30;i++)
{
*wsk1 = i;
*wsk2 = i;
wsk1++;
wsk2++;
}
wsk1 -=29 ;
wsk2 -= 29;
return wsk1, wsk2;
}
double * kopiowanie(double *wsk1,double*wsk2, double*wsk3)
{
for(int i=0; i<30;i++)
{
*wsk3 = (*wsk1) * (*wsk2);
wsk3++;
wsk2++;
wsk1++;
}
wsk1 -=29;
wsk2 -=29;
wsk3 -=29;
return wsk1,wsk2,wsk3;
}
这是一个内存损坏错误,它发生是因为你delete
你没有new
东西。
这段代码错了:
wsk1 -=29;
wsk2 -=29;
wsk3 -=29;
你有三十个循环迭代,意味着三十次调用++
,这意味着你需要-= 30
。
当你弄错了,你传递给delete
的指针是不正确的。
另外, return wsk1, wsk2;
不会做你认为它做的事情,而不是你正在使用这些函数的返回值。
正如Orbit中的Lightness Races所说,你正在计算错误的“旧”指针。
原则上,当你分配一些东西(使用new
, malloc
或其他方法)时,最好不要修改“原始指针”。 改为制作副本,并对其进行处理。 或者在这种情况下,如果你使用索引变量,例如wsk1[i]
而不是wsk1++
来获得你想要的点,你可能会从编译器获得更好的代码。
此外,在您的函数中,您尝试重置指针,这是完全没有必要的,因为您在本地副本上操作(但同样,您可以使用[i]
来代替索引,这将同样有意义,真的)。
我添加了另一个用于将它们分配到表的“高度”的指针,这一切都很有效,感谢很多人的建议;)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.