0

我今天在 c 编程中遇到了一个奇怪的问题。我编写了一个用于服务器客户端通信的程序并在其上应用了字符串比较函数,但是如果我将字符串与 buf 中的内容进行比较,该函数将不起作用。我还检查了 buf 中的数据是否与我在几次迭代后输入的数据不同,但结果是否定的,并且数据与我输入的数据相同。那为什么不strcmp工作。这是代码:

char buf[1024];
while(1)
{
    int readbytes=read(communFd,buf,1024);

    write(STDOUT_FILENO,buf,readbytes);


   if(!strcmp(buf,"exitChat"))
    {
        printf("Chat terminating...\n");
        break;
    }
}

问候

4

3 回答 3

6

read()不会终止strcmp()依赖的缓冲区,您必须明确执行此操作:

int readbytes=read(communFd,buf,1023); /* Read one less for null terminator. */
if (readBytes != -1)
{
    buf[readBytes] = 0;
    if(!strcmp(buf,"exitChat"))
    {
    }
}

或者,正如其他人所提到的,使用不依赖于空终止符存在的不同函数。

请注意,read()它不能保证读取请求的字节数,如果读取的字节数较少,则不会将其视为错误。从链接的参考页面:

成功时,返回读取的字节数(零表示文件结束),文件位置提前该数字。如果此数字小于请求的字节数,则不是错误;这可能会发生,例如因为现在实际可用的字节数较少(可能是因为我们接近文件结尾,或者因为我们正在从管道或终端读取),或者因为 read() 被中断信号。出错时,返回 -1,并适当设置 errno。在这种情况下,未指定文件位置(如果有)是否更改。

为确保收到完整的消息,您需要将数据添加到正在发送的文本中,以便接收者知道何时收到完整的消息。这可能是:

  • 在文本之前加上它的长度。
  • 使用标记值来指示消息的结束,例如一个\n字符来指示结束。代码的结构将更改为read()在循环中调用,直到\n找到将读取的每个字节附加到数组中为止。
于 2013-01-28T17:08:52.077 回答
2

strcmp将比较两个以 null 结尾的 char 数组。 read不会以空值终止您从文件描述符中读取的缓冲区。除非您知道文件中应该有'\0'字节,否则您可以尝试使用strncmp(buf,"exitChat", sizeof("exitChat")-1)

于 2013-01-28T17:09:30.713 回答
1

既然你有readbytes,只比较那么多字节:

if(!strncmp(buf,"exitChat",readbytes))
于 2013-01-28T17:09:51.813 回答