[英]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.