6.20作业

#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>
#include <sys/wait.h>
#include <signal.h>
#include <stdlib.h>

#define PORT 8888
#define IP "192.168.124.39"

#define ERR_MSG(msg) do{\
	fprintf(stderr,"line:%d",__LINE__);\
	fprintf(stderr,"func:%s",__func__);\
	perror(msg);\
}while(0)
void tx(int newfd,	struct sockaddr_in cin);


void bh(int a){
	while(waitpid(-1,NULL,WNOHANG)>0);
}
int main(int argc, const char *argv[])
{
	//创建流式套节奏
	int sfd=socket(AF_INET,SOCK_STREAM,0);
	if(sfd<0){
		ERR_MSG("socket");
		return -1;
	}
	printf("流式套节奏创建完毕 sfd=%d\n",sfd);


	//允许端口快速被复用
	int reuse = 1;
	if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
	{
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("允许端口快速重用\n");



	//填充服务器地址信息结构体给bind函数使用
	//真实的地址信息结构体根据地址族制度,AF_INET-->>man 7 ip
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;//必须填AF_INET
	sin.sin_port=htons(PORT);//端口号的网络字节序 1024~49151
	sin.sin_addr.s_addr=inet_addr(IP);//本机IP,ifconfig,必须是桥接模式

	//绑定服务器地址信息,必须绑定
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("bing");
		return -1;
	}
	//将套节奏设置为被动监听状态
	if(listen(sfd,128)<0){
		ERR_MSG("listen");
		return -1;
	}
	printf("监听成功\n");
	//获取连接成功的客户端信息,生成一个新的套节奏文件描述符
	struct sockaddr_in cin;
	socklen_t addrlen=sizeof(cin);
	if(signal(17,bh)==SIG_ERR){
		ERR_MSG("signal");
		return -1;
	}
	while(1){
		int newfd=accept(sfd,(struct sockaddr*)&cin,&addrlen);
		if(newfd<0){
			ERR_MSG("accpet");
			return -1;
		}
		printf("[%s:%d] newfd=%d 客户端链接成功\n",\
				inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd);
		pid_t pid=fork();
		if(pid==0){

			tx(newfd,cin);
			close(1);
			exit(1);

		}
		close(newfd);
	}
	//关闭文件描述符
	if(close(sfd)<0){
		ERR_MSG("close");
		return -1;
	}
	return 0;
}

void tx(int newfd,	struct sockaddr_in cin){
	char buf[128]="";
	ssize_t res;
	char buf2[128]="";
	ssize_t res2;
	while(1){
		bzero(buf,sizeof(buf));
		//接收
		res=recv(newfd,buf,sizeof(buf),0);
		if(res<0){
			ERR_MSG("recv");
			break;
		}else if(res==0){
			printf("[%s:%d]客户端下线\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));
			break;
		}
		printf("[%s:%d]newfd=%d: %s\n",\
				inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd,buf);
		//发送
		res2=send(newfd,buf,sizeof(buf),0);
		if(res2<0){
			ERR_MSG("send");
			break;
		}
		printf("发送成功\n");
	}
}
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>      
#define PORT 6666
#define IP "192.168.124.255"

#define ERR_MSG(msg) do{\
	fprintf(stderr,"line:%d",__LINE__);\
	fprintf(stderr,"func:%s",__func__);\
	perror(msg);\
}while(0)

int main(int argc, const char *argv[])
{
	//创建报式套节字
	int sfd = socket(AF_INET,SOCK_DGRAM,0);
	if(sfd<0){
		ERR_MSG("sfd");
		return -1;
	}
	printf("报式套接字创建成功,sfd=%d\n",sfd);

	//允许端口快速被复用
	int reuse = 1;
	if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
	{
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("允许端口快速重用\n");

	//填充服务器的地址信息结构体给bind函数使用
	//真实的地址信息结构体根据地址族制度,AF_INET-->>man 7 ip
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;//必须填AF_INET
	sin.sin_port=htons(PORT);//端口号的网络字节序 1024~49151
	sin.sin_addr.s_addr=inet_addr(IP);//本机IP,ifconfig,必须是桥接模式

	//绑定服务器的地址信息,必须绑定
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("bing");
		return -1;
	}
	printf("绑定成功\n");
	char buf[128]="";
	struct sockaddr_in cin;//存储接收到的对端的地址信息
	socklen_t addrlen=sizeof(cin);
	while(1){
		bzero(buf,sizeof(buf));
		//接收数据
		//if(recvfrom(sfd,buf,sizeof(buf),0,NULL,NULL)<0){
		if(recvfrom(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,&addrlen)<0){
			ERR_MSG("recvrom");
			return -1;
		}
		printf("[%s:%d]:%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buf);
		//发送数据
		/*
		strcat(buf,"*-*");
		if(sendto(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,sizeof(cin))<0){
			ERR_MSG("sendto");
			return -1;
		}
		printf("发送成功\n");*/
	}
	//关闭套接字文件描述符
	return 0;
}
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>      
#define PORT 6666
#define IP "192.168.124.255"

#define ERR_MSG(msg) do{\
	fprintf(stderr,"line:%d",__LINE__);\
	fprintf(stderr,"func:%s",__func__);\
	perror(msg);\
}while(0)

int main(int argc, const char *argv[])
{
	//创建报式套节字
	int sfd = socket(AF_INET,SOCK_DGRAM,0);
	if(sfd<0){
		ERR_MSG("sfd");
		return -1;
	}
	printf("报式套接字创建成功,sfd=%d\n",sfd);

	//允许端口快速被复用
	int reuse = 1;
	if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
	{
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("允许端口快速重用\n");
	int b=1;
	if(setsockopt(sfd,SOL_SOCKET,SO_BROADCAST,&b,sizeof(b))<0){
		ERR_MSG("setsockopt");
		return -1;
	}
	//填充服务器的地址信息结构体给bind函数使用
	//真实的地址信息结构体根据地址族制度,AF_INET-->>man 7 ip
	
	//填充对端地址信息结构体,给se
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;//必须填AF_INET
	sin.sin_port=htons(PORT);//端口号的网络字节序 1024~49151
	sin.sin_addr.s_addr=inet_addr(IP);//本机IP,ifconfig,必须是桥接模式

	//绑定服务器的地址信息,必须绑定
	/*
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("bing");
		return -1;
	}
	printf("绑定成功\n");
	*/
	char buf[128]="";
	char buf2[128]="";
	struct sockaddr_in cin;//存储接收到的对端的地址信息
	socklen_t addrlen=sizeof(cin);
	while(1){

		bzero(buf2,sizeof(buf));
		//发送数据
		printf("请输入:");
		fgets(buf2,sizeof(buf2),stdin);
		buf[strlen(buf)-1]='\0';
		if(sendto(sfd,buf2,sizeof(buf2),0,(struct sockaddr*)&sin,sizeof(sin))<0){
			ERR_MSG("sendto");
			return -1;
		}
		printf("发送成功\n");

/*
		bzero(buf,sizeof(buf));
		//接收数据
		//if(recvfrom(sfd,buf,sizeof(buf),0,NULL,NULL)<0){
		if(recvfrom(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,&addrlen)<0){
			ERR_MSG("recvrom");
			return -1;
		}
		printf("[%s:%d]:%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buf);
		*/
	}
	//关闭套接字文件描述符
	close(sfd);
	return 0;
}
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>      
#define PORT 6666 //端口号 1024~49151
#define IP "192.168.124.39" //本机IP
#define IP2 "224.1.2.3"//组播IP 224.0.0.0~239.255.255.255
#define ERR_MSG(msg) do{\
	fprintf(stderr,"line:%d",__LINE__);\
	fprintf(stderr,"func:%s",__func__);\
	perror(msg);\
}while(0)

int main(int argc, const char *argv[])
{
	//创建报式套节字
	int sfd = socket(AF_INET,SOCK_DGRAM,0);
	if(sfd<0){
		ERR_MSG("sfd");
		return -1;
	}
	printf("报式套接字创建成功,sfd=%d\n",sfd);

	//允许端口快速被复用
	int reuse = 1;
	if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
	{
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("允许端口快速重用\n");
	//定义多播组结构体
	struct ip_mreqn mq;
	mq.imr_multiaddr.s_addr=inet_addr(IP2);
	mq.imr_address.s_addr=inet_addr(IP);
	mq.imr_ifindex=0;//网络索引号,0自动查找
	//加入多播组
	if(setsockopt(sfd,IPPROTO_IP,IP_ADD_MEMBERSHIP,&mq,sizeof(mq))<0){
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("加入多播组成功\n");
	//填充服务器的地址信息结构体给bind函数使用
	//真实的地址信息结构体根据地址族制度,AF_INET-->>man 7 ip
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;//必须填AF_INET
	sin.sin_port=htons(PORT);//端口号的网络字节序 1024~49151
	sin.sin_addr.s_addr=inet_addr(IP2);//本机IP,ifconfig,必须是桥接模式

	//绑定服务器的地址信息,必须绑定
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("bing");
		return -1;
	}
	printf("绑定成功\n");
	char buf[128]="";
	struct sockaddr_in cin;//存储接收到的对端的地址信息
	socklen_t addrlen=sizeof(cin);
	while(1){
		bzero(buf,sizeof(buf));
		//接收数据
		//if(recvfrom(sfd,buf,sizeof(buf),0,NULL,NULL)<0){
		if(recvfrom(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,&addrlen)<0){
			ERR_MSG("recvrom");
			return -1;
		}
		printf("[%s:%d]:%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buf);
		//发送数据
		/*
		strcat(buf,"*-*");
		if(sendto(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,sizeof(cin))<0){
			ERR_MSG("sendto");
			return -1;
		}
		printf("发送成功\n");*/
	}
	//关闭套接字文件描述符
	return 0;
}
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>      
#define PORT 6666
#define IP "224.1.2.3"

#define ERR_MSG(msg) do{\
	fprintf(stderr,"line:%d",__LINE__);\
	fprintf(stderr,"func:%s",__func__);\
	perror(msg);\
}while(0)

int main(int argc, const char *argv[])
{
	//创建报式套节字
	int sfd = socket(AF_INET,SOCK_DGRAM,0);
	if(sfd<0){
		ERR_MSG("sfd");
		return -1;
	}
	printf("报式套接字创建成功,sfd=%d\n",sfd);

	//允许端口快速被复用
	int reuse = 1;
	if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
	{
		ERR_MSG("setsockopt");
		return -1;
	}
	printf("允许端口快速重用\n");
	//填充服务器的地址信息结构体给bind函数使用
	//真实的地址信息结构体根据地址族制度,AF_INET-->>man 7 ip
	
	//填充对端地址信息结构体,给se
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;//必须填AF_INET
	sin.sin_port=htons(PORT);//端口号的网络字节序 1024~49151
	sin.sin_addr.s_addr=inet_addr(IP);//本机IP,ifconfig,必须是桥接模式

	//绑定服务器的地址信息,必须绑定
	/*
	if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("bing");
		return -1;
	}
	printf("绑定成功\n");
	*/
	char buf[128]="";
	char buf2[128]="";
	struct sockaddr_in cin;//存储接收到的对端的地址信息
	socklen_t addrlen=sizeof(cin);
	while(1){

		bzero(buf2,sizeof(buf));
		//发送数据
		printf("请输入:");
		fgets(buf2,sizeof(buf2),stdin);
		buf[strlen(buf)-1]='\0';
		if(sendto(sfd,buf2,sizeof(buf2),0,(struct sockaddr*)&sin,sizeof(sin))<0){
			ERR_MSG("sendto");
			return -1;
		}
		printf("发送成功\n");

/*
		bzero(buf,sizeof(buf));
		//接收数据
		//if(recvfrom(sfd,buf,sizeof(buf),0,NULL,NULL)<0){
		if(recvfrom(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,&addrlen)<0){
			ERR_MSG("recvrom");
			return -1;
		}
		printf("[%s:%d]:%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buf);
		*/
	}
	//关闭套接字文件描述符
	close(sfd);
	return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用qwt6.20,您需要按照以下步骤进行操作: 1. 首先,您可以从SourceForge的网站下载qwt6.20的安装文件。 2. 在QT 5.15.0中,一些目录发生了变化,如果您想在qt 5.15.0中构建qwt,您需要修改qwt的源代码。您可以在qwt_global.h文件中添加以下代码段: #if defined(_WIN32) #if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0) #include <QtGui/QPainterPath> #endif #endif 这段代码可以在mvcs2019和qwt 6.1.4中工作。 3. 安装qwt的Designer显示的控件。您可以按照安装文件中的说明进行安装。 4. 如果您想直接从官方网站安装QT,请下载QT Creator 8.0.2和Qt 5.15.2,并选择MSVC2015-64bit作为编译器。然后,您可以从官方网站下载QWT 6.1.4或更高版本,并解压它。 以上是使用qwt6.20的一般步骤。根据您的需求和具体环境,可能还需要进行其他配置和设置。请确保您按照相关文档和指南进行操作,以确保正确地使用qwt6.20。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [qwt6.2.0 msvc编译](https://blog.csdn.net/superkeep/article/details/124094430)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [QT5.15.2+QWT6.2.0 配置 综述](https://blog.csdn.net/weixin_42462856/article/details/128610604)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值