循环TCP通信C ++

时间:2016-01-22 09:52:25

标签: c++ tcp

我有一个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 ++的新手。请举例说明您的解决方案。

1 个答案:

答案 0 :(得分:2)

char buffer[1]; ... bzero(buffer,256);

当然,在你整个堆栈损坏后,其他合理的代码突然失败是可以理解的。