0

我正在调整数组的大小。调整大小(将大小加倍)似乎可以正常工作,但是当我将更多文本发送到调整大小的数组时,当它达到调整大小之前数组的限制时,我得到一个“调试断言失败!表达式: (L"缓冲区太小" && 0)" 错误。我尝试了几种不同的方法,总是得到相同的结果。

    static int ReadBufferSize, totalChars;    
    static char *ReadBuffer = NULL;
    ReadBuffer = (char *)malloc(ReadBufferSize);

    ...

    //Double buffer size.
    if((float)totalChars > (0.75f) * (float)ReadBufferSize)
    {
        char *tempBuffer = NULL;
        tempBuffer = (char *)malloc(2 * ReadBufferSize); 
        if(tempBuffer == NULL)
            free(tempBuffer);
        else
        {
            memcpy(tempBuffer,ReadBuffer,strlen(ReadBuffer)+1);
            free(ReadBuffer);
            ReadBuffer = tempBuffer;
            tempBuffer = NULL;
            ReadBufferSize *= 2;
        }
    }

对于我的测试,ReadBufferSize 最初设置为 85 个字符。在执行了调整数组大小的代码后,ReadBuffer 中的文本仍然显示在屏幕上。我输入更多字符,它们被发送到数组中,然后从那里显示在屏幕上。但是当字符数达到 85 个字符时,我收到“Debug Assertion Failed! Expression: (L"Buffer is too small" && 0)”错误,此时应该有 170 个字符的空间。我也试过以下。

//Double buffer size.
if((float)totalChars > (0.75f) * (float)ReadBufferSize)
{
    char* temp = 0;
    temp = new char[2 * ReadBufferSize];
    for(unsigned int i = 0; i < strlen(ReadBuffer); i++)
        temp[i] = ReadBuffer[i];
    temp[strlen(ReadBuffer)] = '\0';
    delete[] ReadBuffer;
    ReadBuffer = temp;
    temp = 0;
    ReadBufferSize *= 2;
}

我也试过:

malloc(2 * ReadBufferSize * sizeof(char));

和:

strcpy_s(tempBuffer, strlen(ReadBuffer)+1, ReadBuffer);

非常感谢。

4

2 回答 2

3

由于您没有提供完整的最小程序,因此很难说出了什么问题。您通常应该在调试器中启动程序,在函数中放置断点并重现问题。查看所有变量和函数,例如 strlen()。它们可能会返回您不期望的值。

题外话,但对于实际应用程序,您最好使用 std::string 自动执行所有内存管理技巧。

于 2012-08-20T09:57:19.880 回答
1

我想到了。当我注意到问题时,我正要发布更多代码以向您提供更多信息。我有一个用于数组大小的“pageSize”变量。然后,当我想开始动态更改大小时,我通过创建“ReadBufferSize”变量将数组大小与页面大小分开。不幸的是,我在将字符放入数组的代码段中仍然有“pageSize”:

strcat_s(ReadBuffer, pageSize, keystroke);

我现在已将其更改为

strcat_s(ReadBuffer, ReadBufferSize, keystroke);

一切似乎都在工作。感谢大家花时间看这个。我一直认为问题一定出在调整数组大小的代码部分,而不是其他地方。

于 2012-08-21T13:18:27.883 回答