0

该程序严格只读取字母,并按原样推回向量。但是,文本文件就像任何其他文本文件一样。

我遇到过这个STD bad alloc异常,如下。

char keyArray[5][5];

keyArray[0][1] = 'a';
keyArray[0][2] = 'b';
keyArray[0][3] = 'c';
keyArray[0][4] = 'd';
keyArray[0][5] = 'e';
keyArray[1][1] = 'f';
keyArray[1][2] = 'g';
keyArray[1][3] = 'h';
keyArray[1][4] = 'i';
keyArray[1][5] = 'k';
keyArray[2][1] = 'l';
keyArray[2][2] = 'm';
keyArray[2][3] = 'n';
keyArray[2][4] = 'o';
keyArray[2][5] = 'p';
keyArray[3][1] = 'q';
keyArray[3][2] = 'r';
keyArray[3][3] = 's';
keyArray[3][4] = 't';
keyArray[3][5] = 'u';
keyArray[4][1] = 'v';
keyArray[4][2] = 'w';
keyArray[4][3] = 'x';
keyArray[4][4] = 'y';
keyArray[4][5] = 'z';


ifstream readFile;
vector<char> paddedVector;
char c;
int number_of_chars = 0;
readFile.open ("test.txt", ifstream::in);
while(  !readFile.eof() )
{
    if(readFile.peek() == -1)
        break;
    c = readFile.get();
    if(!isalpha(c))
        continue;

    if(c != '\n') //bad alloc here
    {
        ++number_of_chars;
        paddedVector.push_back(c); //std bad alloc happens here
    }
}

请多多指教。

编辑当我拿走 keyArray 部分时,它工作正常。为什么会这样?我在这里做错了什么?

4

3 回答 3

3

您的问题是以下 5 行:

keyArray[?][5] = '?';

您在keyArray数组边界之外的位置进行索引。它可能已经覆盖了paddedVector对象中的内部指针。反过来,当向量尝试(重新)分配内存时,您会收到此异常,因为delete[]无法理解该地址的来源。


请注意,出于同样的原因,您从 开始您的第一个索引0,您也应该从0!因此,两个索引都应该在范围内[0, 5)

于 2013-04-15T13:40:04.267 回答
1
char keyArray[5][5];
// ...
keyArray[4][5] = 'z';

以上写入超出了数组的末尾。keyArrayare 的有效索引keyArray[0..4][0..4]。您的程序处于未定义的行为领域。

于 2013-04-15T13:38:55.690 回答
1

您错误地寻址内部数组。它们也是基于 0 的,所以格式应该是

keyArray[0][0] = 'a'
.
.
.
keyArray[4][4] = 'z'
于 2013-04-15T13:40:35.040 回答