网络编程9.4

2024-09-05 01:52
文章标签 编程 网络 9.4

本文主要是介绍网络编程9.4,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、多进程多线程并发服务器,再实现一遍(重点模型)。

多进程并发服务器:

#include <myhead.h>
#define SERPORT 9999
#define SERIP "192.168.0.162"
#define BACKLOG 10
void hande(int sss)
{if(sss==SIGCHLD){while(waitpid(-1,NULL,WNOHANG)!=-1);}
}
int main(int argc, const char *argv[])
{if(signal(SIGCHLD,hande)==SIG_ERR){perror("signal");return -1;}int oldfd = socket(AF_INET,SOCK_STREAM,0);if(oldfd==-1){perror("socket");return -1;}int kkk = 666;if(setsockopt(oldfd,SOL_SOCKET,SO_REUSEADDR,&kkk,sizeof(kkk))==-1){perror("setsockopt");return -1;}struct sockaddr_in sin = {.sin_family = AF_INET,.sin_port = htons(SERPORT),.sin_addr.s_addr = inet_addr(SERIP)};if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1){perror("bind");return -1;}if(listen(oldfd,BACKLOG)==-1){perror("listen");return -1;}struct sockaddr_in cin;int cinlen = sizeof(cin);while(1){int newfd = accept(oldfd,(struct sockaddr *)&cin,&cinlen);if(newfd==-1){perror("accept");return -1;}printf("%s:%d:连接成功\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));pid_t pid = fork();if(pid>0){close(newfd);}else if(pid==0){close(oldfd);char buf[1024];while(1){int len = recv(newfd,buf,sizeof(buf),0);if(len==0){printf("客户端退出\n");break;}printf("服务器收到消息:%s\n",buf);strcat(buf,"^_^");putchar(10);send(newfd,buf,sizeof(buf),0);printf("发送成功\n");}close(newfd);exit(0);//退出子进程}else{perror("fork");return -1;}}close(oldfd);return 0;
}

多线程并发服务器:

#include <myhead.h>
#define SERPORT 8888
#define SERIP "192.168.0.162"
#define BACKLOG 20typedef struct
{int newfd;struct sockaddr_in cin;
}LA;void *fun1(void *ddd)
{int newfd = ((LA *)ddd)->newfd;struct sockaddr_in cin = ((LA *)ddd)->cin;char buf[1024];while(1){bzero(buf,sizeof(buf));int len = recv(newfd,buf,sizeof(buf),0);printf("收到%s:%d的信息:%s\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),buf);if(len==0){printf("客户端退出\n");break;}strcat(buf,"JTT1314");send(newfd,buf,sizeof(buf),0);printf("发送成功\n");}pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{int oldfd = socket(AF_INET,SOCK_STREAM,0);if(oldfd==-1){perror("socket");return -1;}int BMWm = 4;if(setsockopt(oldfd,SOL_SOCKET,SO_REUSEADDR,&BMWm,sizeof(BMWm))==-1){perror("setsockopt");return -1;}printf("端口号快速复用成功\n");struct sockaddr_in sin = {.sin_family = AF_INET,.sin_port = htons(SERPORT),.sin_addr.s_addr = inet_addr(SERIP)};if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1){perror("bind");return -1;}if(listen(oldfd,BACKLOG)==-1){perror("listen");return -1;}printf("监听成功\n");struct sockaddr_in cin;int cinlen = sizeof(cin);LA MSG;while(1){int newfd = accept(oldfd,(struct sockaddr *)&cin,&cinlen);if(newfd==-1){perror("accept");return -1;}printf("%s:%d发来请求\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));MSG.newfd = newfd;MSG.cin = cin;pthread_t tid;if(pthread_create(&tid,NULL,fun1,&MSG)!=0){perror("pthread_create");return -1;}pthread_detach(tid);}close(oldfd);return 0;
}

2、广播发送接收端,自己实现一遍(重点模型)

发送端:

#include <myhead.h>
#define SENDPORT 6666
#define SENDIP "192.168.0.255"
int main(int argc, const char *argv[])
{int oldfd = socket(AF_INET,SOCK_DGRAM,0);if(oldfd==-1){perror("socket");return -1;}int kkk = 2;if(setsockopt(oldfd,SOL_SOCKET,SO_BROADCAST,&kkk,sizeof(kkk))==-1){perror("setsockopt");return -1;}printf("设置允许广播成功\n");struct sockaddr_in send = {.sin_family = AF_INET,.sin_port = htons(SENDPORT),.sin_addr.s_addr = inet_addr(SENDIP)};struct sockaddr_in ree;int reelen = sizeof(ree);char buf[1024];while(1){bzero(buf,sizeof(buf));sleep(2);strcat(buf,"5201314");sendto(oldfd,buf,sizeof(buf),0,(struct sockaddr *)&send,sizeof(send));printf("发送成功\n");}close(oldfd);return 0;
}

接收端:

#include <myhead.h>
#define SENDPORT 6666
#define SENDIP "192.168.0.255"
int main(int argc, const char *argv[])
{int oldfd = socket(AF_INET,SOCK_DGRAM,0);if(oldfd==-1){perror("socket");return -1;}struct sockaddr_in ree = {.sin_family = AF_INET,.sin_port = htons(SENDPORT),.sin_addr.s_addr = inet_addr(SENDIP)};if(bind(oldfd,(struct sockaddr *)&ree,sizeof(ree))==-1){perror("bind");return -1;}char buf[1024];while(1){bzero(buf,sizeof(buf));recvfrom(oldfd,buf,sizeof(buf),0,NULL,NULL);printf("%s\n",buf);strcat(buf,"^-^");sendto(oldfd,buf,sizeof(buf),0,(struct sockaddr *)&ree,sizeof(ree));printf("发送成功\n");}return 0;
}

这篇关于网络编程9.4的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137641

相关文章

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同