标签:addr my TCP close sockfd 服务器 sizeof buf
如图:四次挥手,关闭函数,作用:
#if 0//-----2--TCP并发服务器--------//
//----- ----------//
int main()
{
int sockfd = socket(AF_INET, SOCK_STREAM, 0);
if(sockfd<0)
{
printf("socket error\n");
return 0;
}
//设置端口复用
int yes=1;
setsockopt(sockfd, SOL_SOCKET,SO_REUSEADDR,&yes, sizeof(yes));
struct sockaddr_in my_addr;
bzero(&my_addr, sizeof(my_addr));
//服务器绑定
my_addr.sin_family = AF_INET;
my_addr.sin_port = htons(9000);
my_addr.sin_addr.s_addr = htonl(INADDR_ANY);
bind(sockfd, (struct sockaddr *)&my_addr, sizeof(my_addr));
//监听客户
listen(sockfd, 20);
//保存链接的客户端的
struct sockaddr_in cli_addr;
socklen_t len = sizeof(cli_addr);
//保存服务器接收到的信息
char buf[128] = "";
//与客户端通信的临时套接字
int sockfd_new;
//保存客户端的点分十进制
char ip[16] = "";
pid_t pid;
while(1)
{
sleep(1);
bzero(&cli_addr, sizeof(cli_addr));
sockfd_new = accept(sockfd,(struct sockaddr *)&cli_addr, &len );
pid = fork();
if(pid < 0)
{
return;
}
else if(pid == 0)
{
close(sockfd);
inet_ntop(AF_INET, &cli_addr.sin_addr.s_addr, ip, 16);
printf("子进程中 IP %s 已连接服务器\n",ip);
while(1)
{
memset(buf, 0, sizeof(buf));
recv(sockfd_new, buf, sizeof(buf), 0);
printf("收到--buf----%s \n",buf);
send(sockfd_new, buf, strlen(buf), 0);
if(strncmp(buf, "bye", 3) == 0 || strlen(buf) == 0)
{
break;
}
}
printf("子进程中 IP %s 已断开服务器\n",ip);
close(sockfd_new);
exit(0);
}
else
{
close(sockfd_new);
//父子进程中的内容一样的,父进程同样需要关闭,结束的临时套接字
//然后在返回监听
//wait(NULL);
}
}
close(sockfd);
return 0;
}
#endif
标签:addr,my,TCP,close,sockfd,服务器,sizeof,buf 来源: https://blog.csdn.net/HanLongXia/article/details/120496759
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。