bind,address already in use

设置了setsockopt( sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on),任然解决不了问题!
代码如下:

/* 接收方代码 */
#include
#include
#include
#include
#include
#include
#include

struct sockaddr myname;
struct sockaddr from_name;
char buf[80];
main()
{
int sock;
int fromlen, cnt;
int on = 1;
sock = socket(AF_UNIX, SOCK_DGRAM, 0);
if (sock < 0)
{
printf("socket failure %d\n", errno);
exit(1);
}
myname.sa_family = AF_UNIX;
strcpy(myname.sa_data, "/tmp/aaa");
if (setsockopt( sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) != 0)
{
perror("Server setsockopt failed");
return 1;
}

if (bind(sock, &myname, strlen(myname.sa_data) +
         sizeof(myname.sa_family)) < 0)
{
    perror("bind failure:");
    exit(1);
}               /* 建立套接字 */
cnt = recvfrom(sock, buf, sizeof(buf),
               0, &from_name, &fromlen);
if (cnt < 0)
{
    perror("recvfrom failure:");
    exit(1);
}               /* 调用recvfrom函数从套接字接收数据 */
buf[cnt] = '\0';  /* 添加字符串结束标志 */
from_name.sa_data[fromlen] = '\0';
printf("'%s' received from %s\n",
       buf, from_name.sa_data);

}

该回答引用ChatGPT

这段代码是一个接收方的代码,主要实现了从套接字接收来自发送方的数据。

  • 首先,使用 socket 函数创建一个 UNIX 域套接字。

  • 然后,使用 setsockopt 函数设置套接字选项,允许地址重用。

  • 接着,使用 bind 函数将套接字绑定到一个地址。

  • 最后,使用 recvfrom 函数从套接字接收数据,并将其打印出来。

该代码存在一个问题,即在 bind 函数调用时,出现 "bind failure" 错误。这是因为该地址已经被其他进程使用。即使使用 setsockopt 函数允许地址重用,仍然无法解决该问题。要解决这个问题,可以使用 unlink 函数删除该套接字的文件。在调用 bind 函数之前,添加以下代码:

unlink("/tmp/aaa");

这样,就可以避免地址已被使用的问题。