TCP服务端和客户端(9)

继续对process.c代码进行改进,用recvmsg和sendmsg来进行替换。将向量挂载到msghdr的msg_iov的成员变量上进行操作。

#include <sys/uio.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
static struct iovec*vs=NULL,*vc=NULL;
/*服务器对客户端的处理*/
void process_conn_server(int s)
{
	char buffer[30];						/*向量的缓冲区*/
	ssize_t size = 0;
	struct msghdr msg;						/*消息结构*/
	
											/*申请3个向量*/
	struct iovec*v = (struct iovec*)malloc(3*sizeof(struct iovec));
	if(!v){
		printf("Not enough memory\n");
		return;		
	}	
											/**挂接全局变量,便于释放管理*/
	vs = v;
											/*初始化消息*/
	msg.msg_name = NULL;					/*没有名字域*/
	msg.msg_namelen = 0;					/*名字域长度为0*/
	msg.msg_control = NULL;					/*没有控制域*/
	msg.msg_controllen = 0;					/*控制域长度为0*/
	msg.msg_iov = v;						/*挂接向量指针*/
	msg.msg_iovlen = 30;					/*接收缓冲区长度为30*/
	msg.msg_flags = 0;						/*无特殊操作*/
											/*每个向量10个字节的空间*/
	v[0].iov_base = buffer;					/*0~9*/
	v[1].iov_base = buffer + 10;			/*10~19*/
	v[2].iov_base = buffer + 20;			/*20~29*/
											/*初始化长度为10*/
	v[0].iov_len = v[1].iov_len = v[2].iov_len = 10;
	
	for(;;){								/*循环处理过程*/
									/*从套接字中读取数据放到向量缓冲区中*/
		size = recvmsg(s, &msg, 0);	
		if(size == 0){						/*没有数据*/
			return;	
		}
		
		/*构建响应字符,为接收到客户端字节的数量,分别放到3个缓冲区中*/
		sprintf(v[0].iov_base, "%d ", size); 		/*长度*/
		sprintf(v[1].iov_base, "bytes alt"); 		/*“bytes alt”字符串*/
		sprintf(v[2].iov_base, "ogether\n"); 		/*“ogether\n”字符串*/
													/*写入字符串长度*/
		v[0].iov_len = strlen(v[0].iov_base);
		v[1].iov_len = strlen(v[1].iov_base);
		v[2].iov_len = strlen(v[2].iov_base);
		sendmsg(s, &msg, 0);						/*发给客户端*/
	}	
}

/*客户端的处理过程*/
void process_conn_client(int s)
{
	char buffer[30];							/*向量的缓冲区*/
	ssize_t size = 0;
	struct msghdr msg;							/*消息结构*/
	
												/*申请3个向量*/
	struct iovec*v = (struct iovec*)malloc(3*sizeof(struct iovec));
	if(!v){
		printf("Not enough memory\n");
		return;		
	}
	
											/**挂接全局变量,便于释放管理*/
	vc = v;
											/*初始化消息*/
	msg.msg_name = NULL;					/*没有名字域*/
	msg.msg_namelen = 0;					/*名字域长度为0*/
	msg.msg_control = NULL;					/*没有控制域*/
	msg.msg_controllen = 0;					/*控制域长度为0*/
	msg.msg_iov = v;						/*挂接向量指针*/
	msg.msg_iovlen = 30;					/*接收缓冲区长度为30*/
	msg.msg_flags = 0;						/*无特殊操作*/
											/*每个向量10个字节的空间*/
	v[0].iov_base = buffer;					/*0~9*/
	v[1].iov_base = buffer + 10;			/*10~19*/
	v[2].iov_base = buffer + 20;			/*20~29*/
											/*初始化长度为10*/
	v[0].iov_len = v[1].iov_len = v[2].iov_len = 10;
		
	int i = 0;	
	for(;;){								/*循环处理过程*/
								/*从标准输入中读取数据放到缓冲区buffer中*/
		size = read(0, v[0].iov_base, 10);
		if(size > 0){						/*读到数据*/
			v[0].iov_len= size;
			sendmsg(s, &msg,0);				/*发送给服务器*/
			v[0].iov_len = v[1].iov_len = v[2].iov_len = 10;
			size = recvmsg(s, &msg,0);		/*从服务器读取数据*/
			for(i = 0;i<3;i++){
				if(v[i].iov_len > 0){
					write(1, v[i].iov_base, v[i].iov_len);/*写到标准输出*/
				}
			}
		}
	}	
}

/*信号SIGINT的处理函数*/
void sig_proccess(int signo)
{
	printf("Catch a exit signal\n");
													/*释放资源*/	
	free(vc);
	free(vs);
	_exit(0);
}

/*信号SIGPIPE的处理函数*/
void sig_pipe(int sign)
{
	printf("Catch a SIGPIPE signal\n");
													/*释放资源*/	
	free(vc);
	free(vs);
	_exit(0);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会飞的幸运儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值