c - 动态分配卡住

标签 c dynamic-allocation

我正在编写要在 TI 芯片中运行的代码,但我的代码在执行以下代码时卡住了

UChar* message;
UChar* tempMessage;
message = malloc( bytesOfMessage * sizeof(UChar));
int i = 0;
while(true)
{
    int rxBytes = UART_read(handle, rxBuf, 1);

    //System_printf("%d \n",  rxBuf[0]);
    if(rxBuf[0] != 13)
    {
        message[i] = rxBuf[0];
        i++;
        int l = 1;

        if(i == bytesOfMessage)
        {
            System_printf("first Message: \n");
            for(l=0;l<bytesOfMessage;l++)
            {
                //System_printf("%c",message[l]);
            }
            System_printf("End of first Message\n");

            bytesOfMessage += 10;
            //message = realloc(message, bytesOfMessage * sizeof(UChar));


            tempMessage = (UChar*)realloc(message, bytesOfMessage * sizeof(UChar));
            message = tempMessage;
            tempMessage = NULL;


            System_printf("Message2 %d: \n", bytesOfMessage);
            for(l=0;l<bytesOfMessage;l++)
            {
                //System_printf("%c", message[l]);
            }
            System_printf("End of second Message\n");
        }
        UART_write(handle, rxBuf, rxBytes);
    }
    else
    {
        rxBuf[0] = '\r';
        rxBuf[1] = '\n';
        rxBuf[2] = 'n';
        rxBuf[3] = 'e';
        rxBuf[4] = 'w';
        UART_write(handle, rxBuf, 5);
    }
}

UART_read 做什么并不重要。

但重要的是realloc函数。

我第一次使用该代码时,它运行良好。 但第二次就卡住了。 这是应该可以工作的正常代码吗?问题出在芯片还是操作系统上?

最佳答案

我认为,你应该发布整个代码。 在第一个循环之前,您分配大小为“byteOfMessage”的消息缓冲区 但在第一个循环中,您重新分配了具有更大大小 (+10) 的消息。 它可以工作,但有时如果系统无法再分配 10 个字节,则无法工作。 因此,您应该尝试在重新分配后测试 tempMessage。它可能是 NULL!

下面的代码应该可以工作:

    UChar* message;
UChar* tempMessage;
message = malloc(bytesOfMessage * sizeof(UChar));
int i = 0;
while (true)
{
    int rxBytes = UART_read(handle, rxBuf, 1);

    //System_printf("%d \n",  rxBuf[0]);
    if (rxBuf[0] != 13)
    {
        message[i] = rxBuf[0];
        i++;
        int l = 1;

        if (i == bytesOfMessage)
        {
            System_printf("first Message: \n");
            for (l = 0; l<bytesOfMessage; l++)
            {
                //System_printf("%c",message[l]);
            }
            System_printf("End of first Message\n");

            bytesOfMessage += 10;

            tempMessage = (UChar*)realloc(message, bytesOfMessage * sizeof(UChar));
            if (tempMessage == NULL)
            {   /* system can't realloc more bytes */
                tempMessage = malloc(bytesOfMessage * sizeof(UChar));
                memcpy(tempMessage, message, bytesOfMessage - 10);
                free(message);
            }
            message = tempMessage;
            tempMessage = NULL;


            System_printf("Message2 %d: \n", bytesOfMessage);
            for (l = 0; l<bytesOfMessage; l++)
            {
                //System_printf("%c", message[l]);
            }
            System_printf("End of second Message\n");
        }
        UART_write(handle, rxBuf, rxBytes);
    }
    else
    {
        rxBuf[0] = '\r';
        rxBuf[1] = '\n';
        rxBuf[2] = 'n';
        rxBuf[3] = 'e';
        rxBuf[4] = 'w';
        UART_write(handle, rxBuf, 5);
    }
}

您还应该清理您的代码。 祝你好运。

关于c - 动态分配卡住,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42721274/

相关文章:

c - 我没有正确处理多个 block

c - 为什么在 ~16370 个套接字连接后会有很长的暂停?

c - 动态分配数组与使用全局作用域自动声明数组(C 语言)

c - 释放部分动态分配的 block ?

c - Malloc 和 Realloc 不起作用(C11 - CLion)

c++ - 同时使用多个 SIMD 指令集的好处

c - 从 C 控制台获取十六进制值

c - Windows 中的语言环境列表

c++ - 如何正确清理对象指针 vector 中的元素

c++ - 动态数组错误