我有一个C++应用程序,它接收一个字符,并运行一个依赖于它接收的字符的函数。问题是,应用程序一收到一条消息就会停止。
--我需要应用程序在接收到消息之后,再次开始监听同一个端口,但我还没有做到这一点。我试着用一个"while (true)“循环循环它,但是我得到了错误。
还值得注意的是,在服务器成功运行之后,它给出了以下消息:
*堆栈崩溃检测到*:已终止 中止(核心倾弃)
如果在服务器成功完成后再次在同一端口上运行服务器,则会得到:
绑定错误:已在使用的地址
重要代码:
int main(int argc, char *argv[]) {
int sockfd, newsockfd, portno;
socklen_t clilen;
char buffer[1];
struct sockaddr_in serv_addr, cli_addr;
int n;
if (argc < 2) {
fprintf(stderr,"ERROR, no port provided\n");
exit(1);
}
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket");
bzero((char *) &serv_addr, sizeof(serv_addr));
portno = atoi(argv[1]);
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = INADDR_ANY;
serv_addr.sin_port = htons(portno);
if (bind(sockfd, (struct sockaddr *) &serv_addr,
sizeof(serv_addr)) < 0)
error("ERROR on binding");
listen(sockfd,5);
clilen = sizeof(cli_addr);
newsockfd = accept(sockfd,
(struct sockaddr *) &cli_addr,
&clilen);
if (newsockfd < 0)
error("ERROR on accept");
bzero(buffer,256);
n = read(newsockfd,buffer,255);
if (n < 0) error("ERROR reading from socket");
if (buffer[0] == '0') {
lamp();
}
else {
printf("No valid input from client.\n");
}
if (n < 0) error("ERROR writing to socket");
close(newsockfd);
close(sockfd);
return 0;}
编辑:我应该说我是C++的新手。请举一个例子说明你的解决方案。
发布于 2016-01-22 09:56:40
char buffer[1]; ... bzero(buffer,256);
当然,在您破坏了整个堆栈之后,其他合理的代码突然失败是可以理解的。
https://stackoverflow.com/questions/34943675
复制相似问题