我刚刚编写了一个程序,它使用本地套接字在两个进程之间进行通信
如果客户端向服务器发送一条消息,然后关闭连接,则服务器只会收到一条消息
克伦特:
send(srvfd,data,size,0)
close(srvfd)
服务器:
n=recv(fd,buf,size,0)
但是,如果客户端发送一条消息,并且服务器也将一条消息(任何字符串)发送回客户端,则客户端关闭连接,服务器将收到客户端发送的旧消息
客户端:
send(srvfd,data,size,0)
n=recv(srvfd,buf,size,0)
close(srvfd)
服务器:
n=recv(fd,buf,size,0)
send(fd,"response",8,0)
n=recv(fd,buf,size,0) //receive the first message again
这是我的初始化代码:
struct sockaddr_un srvAddr;
int listenFd = socket(PF_UNIX, SOCK_STREAM, 0);
if (listenFd < 0) {
perror("cannot create communication socket");
throw runtime_error("cannot create communication socket");
}
srvAddr.sun_family = AF_UNIX;
strncpy(srvAddr.sun_path, sockFile.c_str(), sockFile.size());
unlink(sockFile.c_str());
int ret = bind(listenFd, (struct sockaddr*) &srvAddr, sizeof(srvAddr));
if (ret == -1) {
perror("cannot bind server socket");
close(listenFd);
unlink(sockFile.c_str());
throw runtime_error("cannot bind server socket");
}
ret = listen(listenFd, BACKLOG);
if (ret < 0) {
perror("cannot listen the client connect request");
close(listenFd);
unlink(sockFile.c_str());
throw runtime_error("cannot listen the client connect request");
}
答案 0 :(得分:2)
send(fd,"response",8,0)
n=recv(fd,buf,size,0) //receive the first message again
不,你没有。你得到的是n == 0
,意思是流的结束。这也意味着零字节被传输到缓冲区,因此现在缓冲区中的所有内容现在都没有意义。
不要忽略返回代码。