0

我有一个函数可以从 IRC 服务器接收 512 字节块的数据并将其打印到终端窗口,它是这样的:

int mainLoop(redchan_t *redchan)
{
    int socketDescriptor = redchan->socketDescriptor, i, bytesReceived;
    char workingBuffer[RECVBUFF] = {[0 ... RECVBUFF - 2] = '0', '\0'};

    puts("Recieving data...");

    do
    {
        if ((bytesReceived = recv(
                socketDescriptor,
                workingBuffer,
                RECVBUFF,
                0)) == 0)
            exit(EXIT_FAILURE);

        for (i = 0; i < bytesReceived; ++i)
            printf("%c", workingBuffer[i]);
    }
    while(1);

    return 0;
}

但我想让它更加正交,所以我取出了对 recv 的调用并将其放入它自己的例程中,如下所示:

int redchanRecv(redchan_t *redchan, int size, char *buffer)
{
    int totalBytes = 0, bytesReceived;

    while (totalBytes < size)
    {
        if ((bytesReceived = recv(
                        redchan->socketDescriptor,
                        buffer + totalBytes,
                        size - totalBytes,
                        0)) <= 0)
            cleanup_redchan(redchan, serverInfo);
        totalBytes += bytesReceived;
    }
    return 0;
}

然后我会在我的主循环的每次迭代中调用 redchanRecv() ,然后打印缓冲区。但是当我运行它时,它会打印出几乎所有内容,除了一行。最后一行永远不会到达终端(它甚至会进入缓冲区吗?)。我真的觉得我犯了一个菜鸟的错误,但如果我能看到它,那就见鬼了。我该如何解决这个问题?

4

1 回答 1

0

stdout在您的系统中默认为行缓冲,添加fflush(stdout)调用以打印最后一行。

于 2014-10-15T03:37:10.723 回答