linux下TCP和UTP

1-Tcp服务器.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{	
	//创建socket
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);   //ipv4协议  流式套接字   具体的协议类型
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	int opt = 1; 
	setsockopt(sockfd,SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));   //地址可以被重复绑定

	struct sockaddr_in server_addr;    //保存服务器的信息

	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");  //127.0.0.1回环ip 表示本机 测试时候可以用 
	//绑定信息
	int ret = bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("bind");
		exit(1);
	}

	//设置监听队列
	ret = listen(sockfd, 10);
	if (-1 == ret)
	{
		perror("listen");
		exit(1);
	}

	printf("等待客户端的连接...\n");
	struct sockaddr_in client_addr;   //用于保存客户端的信息
	int length = sizeof(client_addr);
	//接受连接(建立TCP连接)
	int fd = accept(sockfd, (struct sockaddr *)&client_addr, &length);
	if (-1 == fd)
	{
		perror("accept");
		exit(1);
	}
	printf("接受客户端的连接 %d\n", fd);

	char buf[32] = {0};
	while (1)
	{
		//从fd接收消息,TCP连接相当于一个文件,fd就是文件描述符,从fd读取数据,就是从TCP连接接收数据
		ret = recv(fd, buf, sizeof(buf), 0);
		if (-1 == ret)
		{
			perror("recv");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}
		printf("%s\n", buf);

		memset(buf, 0, sizeof(buf));
	}

	close(fd);
	close(sockfd);

	return 0;
}

2-Tcp客户端.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	//向服务器发起连接
	int ret = connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("connect");
		exit(1);
	}

	char buf[32] = {0};
	while (1)
	{
		scanf("%s", buf);
		ret = send(sockfd, buf, strlen(buf), 0);
		if (-1 == ret)
		{
			perror("send");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}

		memset(buf, 0, sizeof(buf));
	}

	close(sockfd);

	return 0;
}

3-Tcp并发服务器.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <pthread.h>

void *ClientHandler(void *arg)
{
	int ret;
	int fd = *(int *)arg;
	char buf[32] = {0};

	pthread_detach(pthread_self());    //线程结束,自动释放资源

	while (1)
	{
		//从fd接收消息,TCP连接相当于一个文件,fd就是文件描述符,从fd读取数据,就是从TCP连接接收数据
		ret = recv(fd, buf, sizeof(buf), 0);
		if (-1 == ret)
		{
			perror("recv");
			exit(1);
		}
		else if (0 == ret)    //客户端异常退出
		{
			break;
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}
		printf("接收%d客户端%s\n", fd, buf);

		memset(buf, 0, sizeof(buf));
	}

	printf("%d 客户端退出!\n", fd);
	close(fd);
}

int main()
{	
	//创建socket
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);   //ipv4协议  流式套接字   具体的协议类型
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	int opt = 1; 
	setsockopt(sockfd,SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));   //地址可以被重复绑定

	struct sockaddr_in server_addr;    //保存服务器的信息

	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");  //127.0.0.1回环ip 表示本机 测试时候可以用 
	//绑定信息
	int ret = bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("bind");
		exit(1);
	}

	//设置监听队列
	ret = listen(sockfd, 10);
	if (-1 == ret)
	{
		perror("listen");
		exit(1);
	}

	printf("等待客户端的连接...\n");
	struct sockaddr_in client_addr;   //用于保存客户端的信息
	int length = sizeof(client_addr);
	while (1)
	{
		//接受连接(建立TCP连接)
		int fd = accept(sockfd, (struct sockaddr *)&client_addr, &length);
		if (-1 == fd)
		{
			perror("accept");
			exit(1);
		}
		printf("接受客户端的连接 %d\n", fd);

		//为每一个客户端创建新的线程
		pthread_t tid;
		ret = pthread_create(&tid, NULL, ClientHandler, &fd);
		if (ret != 0)
		{
			perror("pthread_create");
			exit(1);
		}
		usleep(10000);
	}

	close(sockfd);

	return 0;
}

4-Tcp客户端.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	//向服务器发起连接
	int ret = connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("connect");
		exit(1);
	}

	char buf[32] = {0};
	while (1)
	{
		scanf("%s", buf);
		ret = send(sockfd, buf, strlen(buf), 0);
		if (-1 == ret)
		{
			perror("send");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}

		memset(buf, 0, sizeof(buf));
	}

	close(sockfd);

	return 0;
}

5-Udp服务器.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_DGRAM, 0);    //IPV4协议   数据包套接字
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	//绑定信息
	int ret = bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("bind");
		exit(1);
	}

	char buf[32] = {0};
	struct sockaddr_in client_addr;    //用于保存客户端的信息
	int length = sizeof(client_addr);
	while (1)
	{
		ret = recvfrom(sockfd, buf, sizeof(buf), 0, (struct sockaddr *)&client_addr, &length);
		if (-1 == ret)
		{
			perror("recvfrom");
			exit(1);
		}

		printf("接收%d : %s\n", client_addr.sin_port, buf);

		memset(buf, 0, sizeof(buf));
	}

	return 0;
}

6-Udp客户端.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	char buf[32] = {0};
	int ret;
	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");

	while (1)
	{
		scanf("%s", buf);

		ret = sendto(sockfd, buf, strlen(buf), 0, (struct sockaddr *)&server_addr, sizeof(server_addr));
		if (-1 == ret)
		{
			perror("sendto");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}
			
		memset(buf, 0, sizeof(buf));
	}

	close(sockfd);

	return 0;
}

7-select服务器.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <sys/select.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>

int main()
{	
	int fd[1024] = {0};
	//创建socket
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);   //ipv4协议  流式套接字   具体的协议类型
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	int opt = 1; 
	setsockopt(sockfd,SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));   //地址可以被重复绑定

	struct sockaddr_in server_addr;    //保存服务器的信息

	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");  //127.0.0.1回环ip 表示本机 测试时候可以用 
	//绑定信息
	int ret = bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("bind");
		exit(1);
	}

	//设置监听队列
	ret = listen(sockfd, 10);
	if (-1 == ret)
	{
		perror("listen");
		exit(1);
	}

	fd_set readfd, tmpfd;         //定义集合
	FD_ZERO(&readfd);             //清空集合
	FD_SET(sockfd, &readfd);      //添加到集合
	int maxfd = sockfd, i = 0;
	struct sockaddr_in client_addr;   //用于保存客户端的信息
	int length = sizeof(client_addr);
	char buf[32] = {0};

	while (1)                     //循环服务器
	{
		tmpfd = readfd;
		ret = select(maxfd + 1, &tmpfd, NULL, NULL, NULL);   //监听集合是否可读  最后一个NULL表示阻塞
		if (-1 == ret)
		{	
			perror("select");
			exit(1);
		}
		//有文件描述符可读
		if (FD_ISSET(sockfd, &tmpfd))      //判断sockfd是否还留在集合里面  判断是否有客户端发起连接
		{
			for (i = 0; i < 1024; i++)    //选择合适的i
			{
				if (fd[i] == 0)
				{
					break;
				}
			}
			fd[i] = accept(sockfd, (struct sockaddr *)&client_addr, &length);
			if (-1 == fd[i])
			{
				perror("accept");
				exit(1);
			}

			printf("接受来自%s的客户端的连接 fd = %d\n", inet_ntoa(client_addr.sin_addr), fd[i]);

			FD_SET(fd[i], &readfd);       //新的文件描述符加入到集合中
			if (maxfd < fd[i])
			{
				maxfd = fd[i];
			}
		}
		else                               //有客户端发消息
		{
			for (i = 0; i < 1024; i++)
			{
				if (FD_ISSET(fd[i], &tmpfd))    //判断是哪个fd可读
				{
					ret = recv(fd[i], buf, sizeof(buf), 0);
					if (-1 == ret)
					{	
						perror("recv");
					}
					else if (0 == ret)  
					{	
						close(fd[i]);    //关闭TCP连接
						FD_CLR(fd[i], &readfd);    //从集合中清除掉
						printf("客户端%d下线!\n", fd[i]);
						fd[i] = 0;
					}
					else 
					{
						printf("收到%d客户端的消息%s\n", fd[i], buf);
					}
					memset(buf, 0, sizeof(buf));
					break;		
				}
			}
		}
	}
	
	return 0;
}

8-客户端.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	//向服务器发起连接
	int ret = connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("connect");
		exit(1);
	}

	char buf[32] = {0};
	while (1)
	{
		scanf("%s", buf);
		ret = send(sockfd, buf, strlen(buf), 0);
		if (-1 == ret)
		{
			perror("send");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}

		memset(buf, 0, sizeof(buf));
	}

	close(sockfd);

	return 0;
}

9-epoll服务器.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <sys/epoll.h>

#define MAXSIZE     256

int main()
{	
	//创建socket
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);   //ipv4协议  流式套接字   具体的协议类型
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	int opt = 1; 
	setsockopt(sockfd,SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));   //地址可以被重复绑定

	struct sockaddr_in server_addr;    //保存服务器的信息

	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");  //127.0.0.1回环ip 表示本机 测试时候可以用 
	//绑定信息
	int ret = bind(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("bind");
		exit(1);
	}

	//设置监听队列
	ret = listen(sockfd, 10);
	if (-1 == ret)
	{
		perror("listen");
		exit(1);
	}

	int epfd = epoll_create(MAXSIZE);   //创建epoll对象
	if (-1 == epfd)
	{
		perror("epoll_create");
		exit(1);
	}

	struct epoll_event ev, events[MAXSIZE] = {0};
	ev.events = EPOLLIN;       //监听sockfd可读
	ev.data.fd = sockfd;   
	ret = epoll_ctl(epfd, EPOLL_CTL_ADD, sockfd, &ev);
	if (-1 == ret)
	{
		perror("epoll_ctl");
		exit(1);
	}

	struct sockaddr_in client_addr;   //用于保存客户端的信息
	int length = sizeof(client_addr), i;
	char buf[32] = {0};
	
	while (1)
	{
		int num = epoll_wait(epfd, events, MAXSIZE, -1);   //-1表示阻塞 
		if (-1 == num)
		{
			perror("epoll_wait");
			exit(1);
		}

		for (i = 0; i < num; i++)
		{
			if (events[i].data.fd == sockfd)    //有客户端发起连接
			{
				int fd = accept(sockfd, (struct sockaddr *)&client_addr, &length);
				if (-1 == fd)
				{
					perror("accept");
					exit(1);
				}

				printf("接受来自%s的连接fd=%d\n", inet_ntoa(client_addr.sin_addr), fd);

				//为新的文件描述符注册事件
				ev.data.fd = fd;
				ev.events = EPOLLIN;
				ret = epoll_ctl(epfd, EPOLL_CTL_ADD, fd, &ev);
				if (-1 == ret)
				{
					perror("epoll_ctl");
				}
			}
			else
			{
				if (events[i].events & EPOLLIN)   //如果事件是可读的
				{
					ret = recv(events[i].data.fd, buf, sizeof(buf), 0);
					if (-1 == ret)
					{
						perror("recv");
					}
					else if (0 == ret)
					{
						ev.data.fd = events[i].data.fd;
						ev.events = EPOLLIN;
						epoll_ctl(epfd, EPOLL_CTL_DEL, events[i].data.fd, &ev);   //客户端退出,注销事件
						close(events[i].data.fd);
					}
					else
					{
						printf("收到%d客户端的消息%s\n", events[i].data.fd, buf);
					}
					memset(buf, 0, sizeof(buf));
				}
			}
		}
	}

	return 0;
}


10-客户端.c

#include <stdio.h>
#include <sys/types.h>          /* See NOTES */
#include <sys/socket.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);
	if (-1 == sockfd)
	{
		perror("socket");
		exit(1);
	}

	struct sockaddr_in server_addr;
	memset(&server_addr, 0, sizeof(server_addr));
	server_addr.sin_family = AF_INET;
	server_addr.sin_port = 8000;
	server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	//向服务器发起连接
	int ret = connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr));
	if (-1 == ret)
	{
		perror("connect");
		exit(1);
	}

	char buf[32] = {0};
	while (1)
	{
		scanf("%s", buf);
		ret = send(sockfd, buf, strlen(buf), 0);
		if (-1 == ret)
		{
			perror("send");
			exit(1);
		}
		if (!strcmp(buf, "bye"))
		{
			break;
		}

		memset(buf, 0, sizeof(buf));
	}

	close(sockfd);

	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值