day38 1220

news2025/1/28 1:12:10

作业1:select客户端

  1 #include <myhead.h>
  2 #define SERPORT 8888
  3 #define SERIP "192.168.125.159"
  4 
  5 #define CLIPORT 6666
  6 #define CLIIP "192.168.125.159"
  7 
  8 int main(int argc, const char *argv[])
  9 {
 10     int ret = -1;
 11     int cfd = -1;
 12     cfd = socket(AF_INET,SOCK_STREAM,0);
 13     PERROR_INFO(cfd);
 14 
 15     printf("cfd = %d\n",cfd);
 16 
 17 
 18     int reuse = 1;
 19     ret = setsockopt(cfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse));
 20     PERROR_INFO(ret);
 21 
 22 
 23     struct sockaddr_in cin;
 24     cin.sin_family = AF_INET;
 25     cin.sin_port = htons(CLIPORT);
 26     cin.sin_addr.s_addr = inet_addr(CLIIP);
 27 
 28     ret = bind(cfd,(struct sockaddr *)&cin,sizeof(cin));
 29     PERROR_INFO(ret);
 30 
 31 
 32     struct sockaddr_in sin;
 33     sin.sin_family = AF_INET;
 34     sin.sin_port = htons(SERPORT);
 35     sin.sin_addr.s_addr = inet_addr(SERIP);
 36     
 37     ret = connect(cfd,(struct sockaddr *)&sin,sizeof(sin));
 38     PERROR_INFO(ret);
 39 
 40     char wbuf[128];
 41 
 42     fd_set readfds;
 43     FD_ZERO(&readfds);
 44     FD_SET(0,&readfds);
 45     FD_SET(cfd,&readfds);
 46 
 47     fd_set tempfds;
 48 
 49 
 50     while (1)
 51     {
 52         tempfds = readfds;
 53         ret = select(cfd+1,&tempfds,NULL,NULL,NULL);
 54 
 55 
 56         if (FD_ISSET(0,&tempfds))
 57         {
 58 
 59             bzero(wbuf,sizeof(wbuf));
 60             fgets(wbuf,sizeof(wbuf),stdin);
 61             wbuf[strlen(wbuf)-1] = 0;
 62 
 63             send(cfd,wbuf,sizeof(wbuf),0);
 64             bzero(wbuf,sizeof(wbuf));
 65 
 66         }
 67 
 68         if (FD_ISSET(cfd,&tempfds))
 69         {
 70             ret = recv(cfd,wbuf,sizeof(wbuf),0);
 71             if (ret == 0)                                                                                                                                                                                                        
 72             {
 73                 printf("serve is offline\n");
 74                 break;
 75             }
 76             printf("[%s:%d]: %s\n",SERIP,SERPORT,wbuf);
 77         }
 78 
 79 
 80     }
 81     close(cfd);
 82 
 83     return 0;
 84 }

作业2:poll服务器

  1 #include <myhead.h>
  2 #define PORT 8888
  3 #define IP "192.168.125.159"
  4 
  5 
  6 int main(int argc, const char *argv[])
  7 {
  8     int ret = -1;
  9     int sfd = -1;
 10     sfd = socket(AF_INET,SOCK_STREAM,0);
 11     PERROR_INFO(sfd);
 12 
 13     printf("sfd = %d\n",sfd);
 14 
 15     int reuse = 1;
 16     ret = setsockopt(sfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse));
 17     PERROR_INFO(ret);
 18 
 19 
 20     struct sockaddr_in sin;
 21     sin.sin_family = AF_INET;
 22     sin.sin_port = htons(PORT);
 23     sin.sin_addr.s_addr = inet_addr(IP);
 24 
 25     ret = bind(sfd,(struct sockaddr *)&sin,sizeof(sin));
 26     PERROR_INFO(ret);
 27 
 28     ret = listen(sfd,128);
 29     PERROR_INFO(ret);
 30 
 31     //ret = accept(sfd,NULL,NULL);
 32     //PERROR_INFO(ret);
 33 
 34     struct sockaddr_in cin;
 35     socklen_t socklen = sizeof(cin);
 36     int newfd = -1;
 37 
 38     char buf[128] = "";
 39 
 40     struct pollfd fds[1024];
 41     fds[0].fd = 0;
 42     fds[0].events = POLLIN;
 43 
 44     fds[1].fd = sfd;
 45     fds[1].events = POLLIN;
 46 
 47     int count = 2;//顺序表的总数
 48 
 49 
 50     char rbuf[128] = "";
 51     struct sockaddr_in cins[1024];
 52 
 53     while (1)
 54     {
 55 
 56         ret = poll(fds,count,-1);
 57 
 58         //printf("aaaaaaaa\n");
 59         if (ret == 0)
 60         {
 61             printf("time out\n");
 62             return -1;
 63         }
 64         else if(ret < 0)
 65         {
 66             PERROR_INFO(-1);
 67         }
 68         for (int index = 0;index <count ;index++ )
 69         {
 70 
 71             if (fds[index].revents != POLLIN)
 72             {
 73                 continue;
 74             }
 75 
 76 
 77             if (fds[index].fd  == sfd)
 78             {
 79                 newfd = accept(sfd,(struct sockaddr *)&cin,&socklen);
 80                 PERROR_INFO(newfd);
 81 
 82                 printf("[%s:%d] :is connect\n",inet_ntoa(cin.sin_addr),ntohs(cin.sin_port));
 83                 count++;
 84                 fds[count-1].fd = newfd;
 85                 fds[count-1].events = POLLIN;
 86                 cins[newfd] = cin;
 87 
 88             }
 89             else if (fds[index].fd == 0)
 90             {
 91 
 92                 scanf("%s",buf);
 93                 printf("get message is %s\n",buf);
 94 
 95                 for (int i = 2;i <count ;i++ )
 96                 {
 97                     send(fds[i].fd,buf,sizeof(buf),0);
 98                 }
 99 
100             }
101             else
102             {
103                 bzero(rbuf,sizeof(rbuf));
104                 ret = recv(fds[index].fd,rbuf,sizeof(rbuf),0);
105 
106                 if (ret == 0)
107                 {
108                     printf("client is offline!!!\n");
109                     close(fds[index].fd);
110                     for (int i = index;i < count-2 ;i++ )
111                     {
112                         fds[i] = fds[i+1];
113                     }
114                     count--;
115                     index--;
116                     continue;
117                 }
118                 printf("[%s:%d]  :recive message is %s\n",inet_ntoa(cins[fds[index].fd].sin_addr),ntohs(cins[fds[index].fd].sin_port),rbuf);
119                 //printf("recive message is %s\n",rbuf);
120                 strcat(rbuf,"*_*");
121                 send(fds[index].fd,rbuf,sizeof(rbuf),0);
122 
123             }                                                                                                                                                                                                                                                                                                                                                                                                                                                          
124 
125         }
126     }
127     close(sfd);
128 
129     return 0;
130 }
~                                                                                                                                                                                                                                                                                                                                                                                                                                                                          
~                                                                                                                                                                                                                                                                                                                                                                                                                                                                          
~                        

思维导图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1327058.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

uni-app的初使用(附源码学习)

uni-app代码编写&#xff0c;基本语言包括js、vue、css。以及ts、scss等css预编译器。 新建项目等基础指路&#xff1a; 关于uni-app的下载及使用-CSDN博客 1.vue文件 由三个一级节点组成&#xff0c;分别是template、script、style <template> </template><…

机器学习 | 密度聚类和层次聚类

密度聚类和层次聚类 密度聚类 背景知识 如果 S 中任两点的连线内的点都在集合 S 内&#xff0c;那么集合 S称为凸集。反之&#xff0c;为非凸集。 DBSCAN 算法介绍 与划分和层次聚类方法不同&#xff0c;DBSCAN(Density-Based Spatial Clustering of Applications with Noi…

Jmeter插件技术:性能测试中服务端资源监控

过程中我们需要不断的监测服务端资源的使用情况&#xff0c;例如CPU、内存、I/O等。 Jmeter的插件技术可以很好的实时监控到服务器资源的运行情况&#xff0c;并以图形化的方式展示出来&#xff0c;非常方便我们性能测试分析。 操作步骤&#xff1a; 1、安装插件管理器 插件…

用最通俗的语言讲解 TCP “三次握手,四次挥手”

目录 一. 前言 二. TCP 报文的头部结构 三. 三次握手 3.1. 三次握手过程 3.2. 为什么要三次握手 四. 四次挥手 4.1. 四次挥手过程 4.2. 为什么要四次挥手 五. 大白话说 5.1. 大白话说三次握手 5.2. 大白话说四次挥手 六. 总结 一. 前言 TCP 是一种面向连接的、可靠…

Ebullient开发文档之OTA升级(从TF中升级简洁明了)

一. 简介 这一篇将给大家介绍如何进行OTA升级(esp32s3), 为了简单方便&#xff0c;可操作性强&#xff0c;这次是从TF中读取固件来进行跟新&#xff0c;本来想看看网上有没有参考的&#xff0c;有是有&#xff0c;但绝大多数都是基于官方的例程&#xff0c;甚至贴出来的源码和…

Spring MVC框架支持RESTful,设计URL时可以使用{自定义名称}的占位符@Get(“/{id:[0-9]+}/delete“)

背景&#xff1a;在开发实践中&#xff0c;如果没有明确的规定URL&#xff0c;可以参考&#xff1a; 传统接口 获取数据列表,固定接口路径&#xff1a;/数据类型的复数 例如&#xff1a;/albums/select RESTful接口 - 根据ID获取某条数据&#xff1a;/数据类型的复数/{id} - 例…

mysql,mysqld,数据库的概念理解,为什么要有数据库,主流数据库,mysql架构介绍,存储引擎介绍,sql语句的分类,查看存储引擎(\G)

目录 概念理解 mysql 狭义 广义 CS模式 mysqld 守护进程 (daemon) 数据库服务 数据库 一般 广义上 数据库 为什么要有数据库 主流数据库​​​​​​​ mysql架构 第一层 -- 链接池 第二层 -- 翻译 第三层 -- 存储引擎​​​​​​​ 存储引擎介绍 总结 …

ansible的脚本—playbook剧本

目录 目录 一、playbook 1、简介 2、playbook组成部分&#xff1a; 3、如何编写Playbook&#xff1f; 4、语句的横向/纵向写法 二、playbook实例&#xff1a; 1、playbook模版&#xff1a; 2、playbook的条件判断&#xff1a; 3、playbook中的循环&#xff1a; 4、循…

【已解决】taos时序数据库3.0版本,怎么按照时间分组?

taos数据库中按照时间分组&#xff0c;在2.4版本时候可以直接使用INTERVAL(time_unit)来查询。例如 前面可以直接添加_ts的。但是在3.0版本之后&#xff0c;如果直接使用的话&#xff0c;只会返回count&#xff1a; 没有前面的时间。那么在3.0版本时候&#xff0c;怎么修改呢&a…

Ubuntu18.04、CUDA11.1安装TensorRT

最近想试试推理加速&#xff0c;因为跑的预测有点慢&#xff0c;一开始是打算从数据处理上实现&#xff0c;采用并行数据处理&#xff0c;但是这个有所难度&#xff0c;而且有几张显卡可用&#xff0c;就想着怎么把显卡利用上。而且了解到推理加速后&#xff0c;就先尝试一下看…

Github项目推荐:在线rename

项目地址 GitHub - JasonGrass/rename: 在线文件批量重命名 项目简介 一个开源的在线重命名文件工具。利用了新的浏览器API获取文件句柄&#xff0c;在不上传文件的情况下对文件进行重命名。可以作为前端文件操作api学习范例。 项目截图

HTML5刷题笔记

在 HTML5 中&#xff0c;onblur 和 onfocus 是&#xff1a;事件属性 onblur 和 onfocus 属于焦点事件&#xff1a; onblur&#xff1a;失去焦点 onfocus&#xff1a;获取焦点 HTML5事件window 事件属性 针对 window 对象触发的事件&#xff1a; onafterprint script 文档…

【Chrome】ERR_SSL_PROTOCOL_ERROR问题

文章目录 前言一、下载二、使用步骤总结 前言 Edge升级最新版后&#xff0c;有的https访问不了&#xff0c;报如下错误 发现新版Chrome以及Chromium内核访问nginx ssl时报错&#xff0c;顺着这个思路接着查看到大佬的结论&#xff1a;服务器nginx使用的openssl版本过低&#…

新下载的Redis启动任务管理器不显示服务

遇到问题&#xff1a;刚刚下载的Redis解压后启动&#xff0c;在任务管理器无法找到Redis服务 但是Redis确实是启动的 解答&#xff1a; 那是因为还需要使用管理员的身份打开终端运行安装一次 命令如下&#xff1a; redis-server.exe --service-install redis.windows.conf --…

Ubuntu 常用命令之 reboot 命令用法介绍

&#x1f4d1;Linux/Ubuntu 常用命令归类整理 reboot命令在Ubuntu系统中用于重新启动系统。这个命令通常需要管理员权限才能执行。 reboot命令的参数如下 -f 或 --force&#xff1a;强制重启&#xff0c;不调用shutdown -r进行友好重启。-p 或 --poweroff&#xff1a;在重启…

7-1 单身狗(PTA - 数据结构)

由于这道题在留的作业中&#xff0c;排序和查找都有&#xff0c;所以我先写这道题&#xff08;图的先放放&#xff09; “单身狗”是中文对于单身人士的一种爱称。本题请你从上万人的大型派对中找出落单的客人&#xff0c;以便给予特殊关爱。 输入格式&#xff1a; 输入第一行…

【Earth Engine】协同Sentinel-1/2使用随机森林回归实现高分辨率相对财富(贫困)制图

目录 1 简介与摘要2 思路3 效果预览4 代码思路5 完整代码6 后记 1 简介与摘要 最近在做一些课题&#xff0c;需要使用Sentinel-1/2进行机器学习制图。 然后想着总结一下相关数据和方法&#xff0c;就花半小时写了个代码。 然后再花半小时写下这篇博客记录一下。 因为基于多次拍…

二叉搜索树(AVL树,红黑树)+封装

就像学习其他的东西一样&#xff0c;首先我们要知道二叉搜索树的作用和定义是什么&#xff01; 首先顾名思义&#xff0c;二叉搜索树肯定是被用来为搜索服务的数据结构。 并且它的搜索效率可以达到logN,也就是一百万的数据也只用查找几十次&#xff08;AVL树可以控制在20次左…

日常工作中常用的抓包工具都有哪些呢?

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

电子合同的分类有哪些?

1、从电子合同订立的具体方式的角度&#xff0c;可分为利用电子数据交换订立的合同和利用电子邮件订立的合同&#xff1b; 2、从电子合同标的物的属性的角度&#xff0c;可分为网络服务合同、软件授权合同、需要物流配送的合同等&#xff1b; 3、从电子合同当事人的性质的角度…