UDP是一种面向无连接的不可靠传输协议,有处理速度快、消耗资源小的特点。

 

好奇UDP通讯怎么实现并发服务。TCP可以通过监听服务,创建新的会话,实现并发;

UDP没有这种监听机制,如何实现并发?

 

其实,UDP本身就可连接多个客户端。UDP是不区分客户端,也不需要等待客户端的连接请求。

这样就不用并发处理了。

 

//UDP服务器的实现

#include <stdio.h>   //printf
#include <arpa/inet.h>   //inet_addr htons
#include <sys/types.h>
#include <sys/socket.h>  //socket 
#include <netinet/in.h>  //sockaddr_in
#include <stdlib.h>  //exit
#include <unistd.h> //close
#include <string.h> //strcat
#include <strings.h> 

#define errlog(errmsg) do{perror(errmsg);\
						  printf("%s,%s,%d\n", __FILE__, __func__, __LINE__);\
                          exit(1);\
						 }while(0)
#define N 128

int main(int argc, const char *argv[])
{
	int sockfd;
	struct sockaddr_in server_addr, client_addr;
	socklen_t addrlen = sizeof(struct sockaddr_in);
	char buf[N] = {};

	//bzero  memset
	bzero(&client_addr, sizeof(client_addr));
	bzero(&server_addr, sizeof(client_addr));

	if(argc < 3)
	{
		printf("argument is too less\n");
		exit(1);
	}

	//创建套接字  --->  socket( )
	if((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0)
	{
		//errlog("fail to socket");
		perror("fail to socket");
		exit(1);
	}

	//填充服务器网络信息结构体 sockaddr_in
	//inet_addr : 将点分十进制IP地址转化为网络能够识别的整型数据
	//htons : 将主机字节序转化为网络字节序
	//atoi :将字符串转化为整型数据
	server_addr.sin_family = AF_INET;
	server_addr.sin_addr.s_addr = inet_addr(argv[1]);
	server_addr.sin_port = htons(atoi(argv[2]));

	//将套接字与网络信息结构体绑定 ---> bind( )
	if(bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) < 0)
	{
		errlog("fail to bind");
	}
	
	while(1)
	{
		if(recvfrom(sockfd, buf, N, 0, (struct sockaddr *)&client_addr, &addrlen) < 0)
		{
			errlog("fail to recvfrom");
		}

		printf("%s ---> %d\n", inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port));

		if(strncmp(buf, "break", 5) == 0)
		{
			break;
		}
		else
		{
			printf("from client >>> %s\n", buf);

			strcat(buf, " *_*");

			if(sendto(sockfd, buf, N, 0, (struct sockaddr *)&client_addr, addrlen) < 0)
			{
				errlog("fail to sendto");
			}
		}
	}

	close(sockfd);

	return 0;
}