[英]Why does my program throws SIGABRT when I try to delete[] array?
我最近遇到了一個非常煩人的錯誤。 當我嘗試delete[]
fileHeader
指向的數組時,程序將引發SIGABRT
信號。
我要指定的一件事是,該程序在帶有Microsoft C ++編譯器的Microsoft Visual C ++ 2012中運行時沒有任何問題,但是在GCC編譯器版本4.6的Code::Blocks
有此錯誤
以下是與此錯誤相關的代碼:
void Image::saveBMP(char fileName[])
{
ofstream file(fileName, ios::binary);
if(file.is_open())
{
char *fileHeader = setupFileHeader();
char *imageHeader = setupImageHeader();
char *imageData = setupImageData();
file.write(fileHeader, 14);
file.write(imageHeader, 40);
file.write(imageData, height*width*4);
delete[] fileHeader;
delete[] imageHeader;
delete[] imageData;
file.close();
}
}
char* Image::setupFileHeader()
{
char *buffer = new char[14];
unsigned fileSize = (unsigned)(width*height*4 + 54);
for(int i = 0;i < 40;i++)
buffer[i] = 0;
buffer[0] = 'B';
buffer[1] = 'M';
buffer[10] = 54;
for(int i = 0;i < 4;i++)
{
buffer[2+i] = (fileSize >> (i*8)) & 0xFF;
}
return buffer;
}
char* Image::setupImageHeader()
{
char *buffer = new char[40];
unsigned rawDataSize = (unsigned)(width*height*4);
unsigned resolution = 2835; //pixels per meter
for(int i = 0;i < 40;i++)
buffer[i] = 0;
buffer[0] = 40;
buffer[12] = 1;
buffer[14] = bpp;
for(int i = 0;i < 4;i++)
{
buffer[4+i] = (width >> (i*8)) & 0xFF;
buffer[8+i] = (-1*height >> (i*8)) & 0xFF;
buffer[20+i] = (rawDataSize >> (i*8)) & 0xFF;
buffer[24+i] = (resolution >> (i*8)) & 0xFF;
buffer[38+i] = (resolution >> (i*8)) & 0xFF;
}
return buffer;
}
char* Image::setupImageData()
{
unsigned rawDataSize = (unsigned)(width*height*4);
char *buffer = new char[rawDataSize];
int k = 0;
for(int i = 0;i < height;i++)
for(int j = 0;j < width;j++)
{
buffer[k++] = pixels[i][j].getBlueByte();
buffer[k++] = pixels[i][j].getGreenByte();
buffer[k++] = pixels[i][j].getRedByte();
}
return buffer;
}
我檢查了一下,當delete[]
想要完成它的工作時, fileHeader
正確指向了應該刪除的數組。 並且該文件已創建並且具有正確的格式(作為BMP圖像文件打開),因此陣列的內容很好。
我真的很想知道為什么會這樣,因為我覺得這很奇怪。
char *buffer = new char[14];
unsigned fileSize = (unsigned)(width*height*4 + 54);
for(int i = 0;i < 40;i++)
buffer[i] = 0;
在這里,您正在分配14個字符的緩沖區。 在循環中,您要填充40次迭代的緩沖區。 這是“數組超出范圍”內存損壞。
幸運的是,VC ++並沒有使它崩潰
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.