3

我目前正在开发一个 UDP 应用程序,该应用程序允许两个用户使用 winsock 库相互交谈。目前,当我的程序运行时,它首先将 sockaddress 保存到向量中,然后当用户发送消息时,它将地址与向量中的第一个地址进行比较。当我调试并比较正在比较的值时,它们完全相同,但我的 if 语句转到 else (它认为地址不相等)

这是我的代码:

#include <WinSock2.h>

sockaddr    clientAddress;

recvfrom( hSocket, msg, MAXLINE, 0, &clientAddress, &cbClientAddress );

myVector.pushback(clientAddress);

if (&clientAddresses[0] == &clientAddress)
{
//is the same address
}
else
{
//not the same address
}

我还尝试在and.sa_data之后使用更具体clientAddress[0]&clientAddress.

谢谢

4

1 回答 1

1

多个问题:

  • 在调用 之前recvfrom,您需要将cbClientAddress(类型socklen_t)初始化为您准备接收的地址信息的字节数,如下所示:

     struct sockaddr clientAddress;
     socklen_t cbClientAddress;
    
     cbClientAddress = sizeof(clientAddress);
     recvfrom(hSocket, msg, MAXLINE, 0, &clientAddress, &cbClientAddress);
    
  • 调用后,cbClientAddress将被接收到的地址的实际长度覆盖。这将比 短sizeof(struct sockaddr)。实际上它将等于,sizeof(struct sockaddr_in)因为这是一个 UDP/IP 套接字。

  • 您必须只比较结构中实际包含数据的部分,而不是整个结构。struct sockaddr_in结构的未使用部分(和之间的大小差异struct sockaddr)可能是垃圾。你不想比较它。这不仅需要在向量中记住结构本身的内容,而且还需要显着长度。

  • 在将保存的地址与您刚刚收到的地址进行比较时,请使用这种伪代码。不要试图比较整个结构(包括尾随未使用的部分)。

    if (
        (saved_length == this_length) &&
        (memcmp(saved_sockaddr, this_sockaddr, this_length) == 0)
    ) {
        it's a match
    }
    
  • 您的代码&clientAddresses[0] == &clientAddress检查结构的地址是否相等。这意味着您正在测试它是否是相同的结构,而不是您想要的,即测试它是否是具有相同内容的结构memcmp按照上面的伪代码使用来比较内容。

于 2012-04-10T00:14:57.270 回答