我有一个C ++应用程序,它接收1个char并运行一个函数,该函数取决于它收到的char。问题是应用程序一收到一条消息就会停止。
我需要应用程序在收到消息后再次开始侦听同一个端口,但我还没有设法这样做。我尝试用“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 ++的新手。请举例说明您的解决方案。答案 0 :(得分:2)
char buffer[1]; ... bzero(buffer,256);
当然,在你整个堆栈损坏后,其他合理的代码突然失败是可以理解的。