我遇到了这个问题:
Debug Assertion失败!
文件: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;
}
答案 0 :(得分:5)
这是一个内存损坏错误,它发生的原因是你delete
你没有new
的事情。
此代码错误:
wsk1 -=29;
wsk2 -=29;
wsk3 -=29;
你有三十次循环迭代,意味着三次调用++
,这意味着你也需要-= 30
。
如果出错,传递给delete
的指针不正确。
此外,return wsk1, wsk2;
不会按照您的想法执行,而不是您正在使用这些函数的返回值。
答案 1 :(得分:0)
正如Orbit中的Lightness Races所说,你正在计算错误的“旧”指针。
原则上,当您分配某些内容(使用new
,malloc
或其他方法)时,最好不要修改“原始指针”。改为制作副本,并对其进行处理。或者在这种情况下,如果使用索引变量,可能会从编译器中获得更好的代码,例如: wsk1[i]
代替wsk1++
来达到您想要的地步。
此外,在您的函数中,您尝试重置指针,这是完全没必要的,因为您在本地副本上操作(但同样,您可以使用[i]
来代替索引,这将使真的很有道理。
答案 2 :(得分:-1)
我添加了另一个用于将它们分配到表的“高度”的指针,这一切都有效,感谢很多人的建议;)