6. 网络编程-网络io与select、poll,epoll

https://0voice.com/uiwebsite/html/courses/v13.7.html

首先看看这个学习计划

  1. 网络、网络编程、网络原理
  2. 基础组件,20个。
  3. 中间件 Redis ,MySQL,Kafka,RPC,Nginx
  4. 开源框架(解决方案)业务开发(工程师开发,写代码)
  5. Docker/K8S,产品角度
  6. 开源代码,写的闭源的。
    火焰图,bpf/ebpf
  7. 分布式,分布式DB,分布式fs。etcd
  8. 项目能与公司业务场景(dkvsstore,图床)

samba配置可以看这个链接

复制代码
#include<stdio.h>
#include<string.h>
#include<errno.h>

#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>

int main() {
	//open
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
	
	struct sockaddr_in servaddr;
	memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
	servaddr.sin_family = AF_INET;
	servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
	servaddr.sin_port = htons(9999);
	if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
		printf("bind failed:%s",strerror(errno));
		return -1;
	}
	listen(sockfd, 10);
	getchar();
	
	
}

然后我们运行:

复制代码
gcc -o multi-io multi-io.c
./multi-io

然后他会阻塞住:

然后我们进入一个可视化工具也是可以看的。

这时候我们已经收到了数据,但是还没有处理。我们上面写的代码就好比一个酒店的服务员。他是可以进去的,但是没有处理。这时候我们要给这个客户端分配一个服务员。

复制代码
#include<stdio.h>
#include<string.h>
#include<errno.h>

#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>

int main() {
	//open
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
	
	struct sockaddr_in servaddr;
	memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
	servaddr.sin_family = AF_INET;
	servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
	servaddr.sin_port = htons(9999);
	if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
		printf("bind failed:%s",strerror(errno));
		return -1;
	}
	listen(sockfd, 10);
	
#if 1
	struct sockaddr_in clientaddr;
	socklen_t len = sizeof(clientaddr);
	int clientfd = accept(sockfd, (struct sockaddr*)&clientaddr, &len);
	
#endif
	getchar();//block
}

一开始的代码阻塞在getchar(),我们一敲回车他就会退出,但是现在代码阻塞在客户端接收这部分了。

然后这时候我们在这个工具中一点击链接他就退出了。也就是有客户端连接他就往下走了。

然后这就引出一个概念,阻塞型IO和非阻塞型IO,阻塞型IO就是等待连接,没有连接就是一直等待着,等待条件满足了之后才往下走。

下面是非阻塞IO:

复制代码
#include<stdio.h>
#include<string.h>
#include<errno.h>

#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<fcntl.h>

int main() {
	//open
	int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
	
	struct sockaddr_in servaddr;
	memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
	servaddr.sin_family = AF_INET;
	servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
	servaddr.sin_port = htons(9999);
	if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
		printf("bind failed:%s",strerror(errno));
		return -1;
	}
	listen(sockfd, 10);
	
	sleep(10);
#if 1

	int flags = fcntl(sockfd, F_GETFL, 0);
	flags |= O_NONBLOCK;
	fcntl(sockfd, F_SETFL, flags);

	struct sockaddr_in clientaddr;
	socklen_t len = sizeof(clientaddr);
	int clientfd = accept(sockfd, (struct sockaddr*)&clientaddr, &len);
	
	printf("clientfd:%d", clientfd);
#endif
	getchar();//block
}
相关推荐
旖-旎10 小时前
《LeetCode 130 被围绕的区域 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
一只旭宝17 小时前
【C++入门精讲22】常见设计模式
c++·设计模式
c++之路19 小时前
Bazel C++ 构建系列文档(三):构建第一个 C++ 项目
开发语言·c++
旖-旎19 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
森G19 小时前
61、信号与槽机制在 TCP 编程中的应用---------网络编程
网络·c++·qt·网络协议·tcp/ip
syagain_zsx20 小时前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q20 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
奇妙方程式21 小时前
2026年第九届GXCPC广西大学生程序设计大赛(热身赛)题解
c++·编程比赛·编程竞赛·gxcpc
Tian_Hang21 小时前
C++原型模式(Protype)
开发语言·c++·算法
FL16238631291 天前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv