二、UDP 编程流程 1.服务器 代码如下(示例): int main() { int sockfd = socket(AF_INET,SOCK_DGRAM,0); assert( sockfd...sockaddr*)&caddr,sizeof(caddr)); } close(sockfd); exit(0); } 2.客户端 代码如下(示例): int main() { int sockfd = socket
有限状态机 相关来源及参考-部分在具体模块有指明 《Linux高性能服务器编程》-游双 ---- 定义 维基百科: 在编程中有限状态机(finite state)是服务器程序逻辑单元内部的一种高效编程方法...,只不过其中的每种状态都是相互独立的 ,状态之前没有相互转移,状态转移需要状态机内部驱动。...return LINE_BAD;// 行出错 } } return LINE_OPEN;// 行数据不完整 } ---- 完整代码 #include socket.h...inet_pton( AF_INET, ip, &address.sin_addr ); address.sin_port = htons( port ); int listenfd = socket...相关参考: Linux C API 参考手册 ---- strcasecmp 功能: 比较两个字符串(忽略大小写), 函数原型: #include int strcasecmp
Socket 编程 6.1 socket 常见API Socket API 是一层网络编程接口,抽象了底层的网络协议,定义在 netinet/in.h 中。...Socket 接口 7.1 创建 Socket 文件描述符 在 TCP 和 UDP 通信中,首先要创建一个 Socket 文件描述符,它本质上是一个网络文件。...7.3 开始监听 Socket (TCP 服务器) 在服务器中,调用 listen() 函数使套接字进入监听状态,准备接受连接请求: int listen(int socket, int backlog...); 功能:让服务器套接字进入监听状态,准备接收客户端连接。...TCP 通信流程 服务器初始化:调用 socket() 创建套接字,调用 bind() 绑定地址和端口,调用 listen() 进入监听状态。
)设置为监听状态,以接受客户端的连接请求。...); 参数说明 sockfd: 这是一个监听套接字描述符(socket file descriptor),通常由 socket 创建并通过 bind 和 listen 设置为监听状态。...调用 listen 将套接字设置为监听状态。 调用 accept 接受客户端的连接请求。 使用 accept 返回的新套接字与客户端通信。 通信完成后,关闭新套接字。...设置为监听状态 n = ::listen(_listensockfd, BACKLOG); if(n < 0) { LOG(LogLevel...EchoServer -- 线程池 引入我们之前写的【Linux】:线程库 Thread.hpp 简单封装 Thread.hpp 以及 单例模式下的【Linux】:日志策略 + 线程池(单例模式 Threadpool.hpp
linux socket的基础 linux的空间分为kernel space 和 user space, 比例是1:3 linux中一切皆文件, 所以用文件描述符来表示socket, 实际上是socket...用来进程与进程之间的通信 socket如何创建 一个进程要创建socket的流程如下所示 1....pathname, MY_SOCK_PATH should be deleted using unlink(2) or remove(3) */ } 如何在linux...上查看socket ll /proc//fd linux默认的三个文件描述符 0 - stdin 1 - stdout 2 - stderr >& 是重定向到文件描述符...基于socket的应用 java nio java nio用channel代替了输入输出流, 这个channel, 就是socket 其原理是使用了linux kernel里的fcntl /*
LOG(LogLevel::FATAL) socket: " << strerror(errno); Die(SOCKET_ERR); }...} private: InetAddr _addr; // 服务器地址包括ip和port int _sockfd; bool _isrunning; // 服务器运行状态...} private: InetAddr _addr; // 服务器地址包括ip和port int _sockfd; bool _isrunning; // 服务器运行状态...private: InetAddr _addr; // 服务器地址包括ip和port int _sockfd; bool _isrunning; // 服务器运行状态...socket socket // client必须也要有自己的ip和端口!但是客户端,不需要自己显示的调用bind!!
在前面几篇文章中,我们实现了Socket编程,也就是基于UDP和TCP进行了网络编程,通过这几次编程我们已经熟悉了Socket编程相关的系统调用,那么这篇文章我们就来使用模版方法模式封装一个Socket...封装Socket 那我们就可以抽象一个Socket的基类,将创建套接字等需要的系统调用在基类中设为纯虚函数,然后我们可以定义两个模板方法,一个UDP的模板方法,一个TCP的模板方法,需要使用哪个传输层协议的网络服务就在主程序中调用哪个模板方法...error"; exit(SOCKET_ERR); } LOG(LogLevel::INFO) socket success...描述: 这是一个由 socket() 创建,并经过 connect()(对于客户端)或 accept()(对于服务器端)处理后的套接字文件描述符。...服务端 封装好之后就是使用封装的Socket来实现服务端,我们已经实现过了,这里就不再介绍了,只需要将原先的原生系统调用换成封装的Socket即可 #pragma once #include "Socket.hpp
TCP socket API 详解 下面介绍程序中用到的 socket API,这些函数都在 sys/socket.h 中。...socket() 作用:打开一个网络通讯端口,如果成功的话,就像 open()一样返回一个文件描述符; 应用程序可以像读写文件一样用 read/write 在网络上收发数据; 返回值:如果 socket...端口号为 SERV_PORT, 我们定义为 8080; listen() 介绍:listen()声明 sockfd 处于监听状态, 并且最多允许有 backlog 个客户端处于连接 等待状态, 如果接收到更多的连接请求就忽略..."; // 我们要获取client的信息:数据(sockfd)+client socket信息(accept || recvfrom) int sockfd..."; // 我们要获取client的信息:数据(sockfd)+client socket信息(accept || recvfrom) int sockfd
如果对你有帮助,麻烦点个在看或点个赞,感谢~ 不管是Qt开发还是linux 嵌入式应用开发,一个人的核心竞争力还是不断思考,也就是不断琢磨。...下面的程序主要是Linux C Socket 读取JSON文件并传输,然后再写入文件,其中使用了cJSON库,关于cJSON库不过多介绍,主要介绍整体的思路。 1....Server 端 使用的是socket 阻塞式,没有使用select、poll、epoll等 接收端按照JSON格式解析数据,并提取感兴趣Key所对应的Value 程序功能挺快就可以做好,做完之后进行拆解...,将socket通信独立出来,JSON解析、写文件、响应客户端JSON数据等分别写成函数。...小结 编译JSON时需要链接linux的数学库 自己琢磨如何拆解函数功能 应用程序也主要是调用别人的api,那么你的核心竞争力是什么呢 ? 如需程序工程可在公众号后台留言。
Socket soket接口是TCP/IP网络的API。网络的socket数据传输是一种特别的I/O,socket也是一种文档描述符。...利用socket()函数打开,返回一个整型的socket描述符,然后建立连接,数据传输等等。...常用的socket类型有:流式socket(SOCK_STREAM)、数据报socket(SOCK_DGRAM)....其中流式socket是采用面向连接的TCP服务,而数据报socket则是无连接的UDP服务 Socket建立 调用: int socket(int domain, int type, int...收到连接请求时,socket执行体将建立一个新的socket,执行体将这个新socket和请求连接进程的地址联系起来,收到服务请求的初始socket仍能够继续在以前的 socket上监听,同时能够在新的
前言 在上一篇文章里面我们介绍了TCP的三次握手和四次挥手过程的介绍以及网络编程里面的一些api接口函数的介绍——Linux系统下socket编程之socket接口介绍(一)。...函数介绍 - 发送和接收 - (1)send和write: 首先说明的一点,之前介绍的socket这个函数,非常类似我们之前介绍的open函数,他们都会返回一下文件描述符;所以这里的send函数和write...函数作用类似,我们用man手册来查看它的具体形式和用法: #include #include socket.h> ssize_t send(int...(这个转换完后不能用于网络传输,还需要调用htons或htonl函数才能将主机字节顺序转化为网络字节顺序,这两个函数先不讲,实战遇到的话,再进行解析),具体可以看下面Linux的源文: inet_aton...(2)struct sockaddr,这个结构体是linux的网络编程接口中用来表示IP地址的 标准结构体,bind、connect等函数中都需要这个结构体,这个结构体是兼容IPV4和IPV6的。
在前面的文件中,我们介绍了linux网络编程中与IP相关的知识和常用的函数总结,本文针对具体的UDP通信,来详细的介绍UDP通信的使用,包括UDP通信中的点对点通信,多播,广播等。...一、UDP通信中服务端和客户端的基本编程框架 与TCP相比较,UDP是面向无连接的通信方式,不需要connect、listen、accept等函数操作,不用维护TCP的连接、断开等状态。...后,配置一下套接字,允许进行发送广播消息,上代码 int set_broadcast = 1; setsockopt(socket, SOL_SOCKET, SO_BROADCAST, &set_broadcast...解决方法如下:(允许端口重用) int on = 1; ret = setsockopt(udp_net_sta.socket, SOL_SOCKET, SO_REUSEADDR, &on, sizeof...(int)); if (ret < 0) { perror("socket set SO_REUSEADDR failed"); } 2、服务端程序,在创建完socket后,有一个bind的操作
二.通过系统调用获取标识符 linux中可以通过 系统调用接口:getpid 获取该进程的PID,getppid可以获取父进程的PID 例: #include #include...} 三.fork函数的认识与理解 fork认识 linux...一般情况下,子进程和父进程也是共享数据的,但是一直共享数据也不现实,因为当我们要修改数据时,会把两个进程的数据都改了,这并不是我们想要的,但是重新开一块空间拷贝父进程的数据又有点浪费,所以linux就使用了一种叫写时拷贝的技术...linux中进程的状态 linux中的进程状态分为这几种 static const char * const task_state_array[] = { "R (running)", /* 0...D状态就算是阻塞状态了,S状态又叫浅度睡眠,D状态又叫深度睡眠,处于深度睡眠的进程不会响应任何请求,你只能慢慢等它结束,或是断电。
3.Linux进程状态 static const char * const task_state_array[] = { "R (running)", /* 0 */ "S (sleeping)",..."T (stopped)", /* 4 */ "t (tracing stop)", /* 8 */ "X (dead)", /* 16 */ "Z (zombie)", /* 32 */ }; Linux...R状态 进程只要是R状态,就一定是在CPU运行吗?...X状态(死亡状态)&&Z状态(僵尸状态) X死亡状态只是一个返回状态,你不会在任务列表里看到这个状态,所以这里这是举例时提及,但不会验证 我们创建进程,是为了进程帮我们办事,同时也关心结果,而main函数的返回值是进程的退出码...linux当进程退出的时候,一般进程不会立即彻底退出,而是要维持一个状态叫做Z状态,也叫做僵尸状态 方便后续父进程读取子进程退出的退出结果 如何让我们看到僵尸状态呢?
Linux进程状态 static const char * const task_state_array[] = { "R (running)", /* 0 */ "S (sleeping)", /*...(stopped)", /* 4 */ "t (tracing stop)", /* 8 */ "X (dead)", /* 16 */ "Z (zombie)", /* 32 */ }; 上面就是Linux...x状态 x状态是死亡状态,当一个进程已经终止并且已经中系统中完全清除。 Z状态 z状态是僵尸状态,与死亡状态不同,z状态是指进程已经终止但父进程还没有还没有读取其退出信息的一种状态。...总结 通过对进程状态转换和 Linux 进程状态的分析,我们了解了操作系统如何通过不同的状态管理进程的执行。...进程的三种基本状态转换解释了进程从创建到结束的生命周期,而 Linux 系统中常见的 R、S、D 等状态则细化了进程在运行、等待以及阻塞中的具体表现。
进程状态 为了弄明白正在运行的进程是什么意思,我们需要知道进程的不同状态。一个进程可以有多个状态,在Linux内核中,进程也可以叫做任务。...在Linux中也是如此,Linux可能存在很多的进程,操作系统要根据它们的状态来决定后续对这些进程的操作。...1.1 通俗的5种状态 进程的状态,通俗的来讲有5种:创建状态、就绪状态、堵塞状态、执行状态、终止状态。 最基本的状态就是:运行状态、就绪状态、堵塞状态。...1.2 进程具体的状态 上面的状态好像和前面我们所写的状态不太一样啊,确实,在前面我们所写为的为进程具体的状态,相当于通俗状态的具体实例。...X死亡状态(dead):这个状态只是一个返回状态,你不会在任务列表里看到这个状态。 说了这么多,有没有可信度呢?当然了下面就是查看进程状态。
前言: 在Linux操作系统中,进程状态是一个重要而又复杂的话题。了解进程状态可以帮助我们更好地理解操作系统的运行机制。那么话不多说,开启我们今天的话题。...内核中的进程状态 Linux内核给出进程状态的几个表述: /* * The task state array is a strange "bitmap" of * reasons to sleep....✈️前后台进程 我们来解释一下为什么我们看到的进程状态是 S+ 或者 R+?在Linux中,存在着 前台进程 和 后台进程 之分。...✈️X状态 X状态很简单,一般X状态表示为进程正常退出的状态,进程退出都是瞬时的,所以这个状态很难给大家演示出来,只需要知道 X状态为进程正常退出状态即可。...其实,在Linux中,如果一个父进程创建了子进程,但是父进程要先比子进程退出,这时候 子进程会被1号进程(操作系统)托管。
个人主页:island1314 个人专栏:Linux—登神长阶 1....7.3 开始监听 Socket (TCP 服务器) 在服务器中,调用 listen() 函数使套接字进入监听状态,准备接受连接请求: int listen(int socket, int backlog...); 功能:让服务器套接字进入监听状态,准备接收客户端连接。...常见用途 允许端口重用:使用 `SO_REUSEADDR`,避免因端口处于 `TIME_WAIT` 状态而无法绑定。...TCP 通信流程 服务器初始化:调用 socket() 创建套接字,调用 bind() 绑定地址和端口,调用 listen() 进入监听状态。
套接字描述符 首先会先到的是文件描述符,对Linux一切皆文件的哲学又多懂了一点儿点儿。 套接字是通信端点的抽象。与应用程序使用文件描述符一样,访问套接字需要使用套接字描述符。...Linux系统是小端字节序。 2.2 地址格式 地址确定了特定通信域中的套接字端点,地址格式与特定的通信域相关。...注意:linux的man命令可以查看api的详细说明,而且还有例子,也挺不错的。 4....传给accept的原始套接字没有关联到这个连接,而是继续保持可用状态并接受其他连接请求。 如果不关心客户端标识,可以将addr和len设置为NULL,否则addr存放的是连接的客户端的地址。...Linux Socket Server 与 Client 例子 个人觉得这只是套接字的入门,如果一个服务器要连接多个客户端呢?以后有机会和大家一起分享下select的套接字用法。
Linux的SOCKET编程详解 1. 网络中进程之间如何通信 进 程通信的概念最初来源于单机系统。...Socket是什么 1、 socket套接字: socket起源于Unix,而Unix/Linux基本哲学之一就是“一切皆文件”,都可以用“打开open –> 读写write/read –>...具体如何实现,可以看看linux的内核 4.1、socket()函数 int socket(int protofamily, int type, int protocol);//返回sockfd...2.为什么TIME_WAIT状态还需要等2MSL后才能返回到CLOSED状态?...,你无法保证你最后发送的ACK报文会一定被对方收到,因此对方处于LAST_ACK状态下的SOCKET可能会因为超时未收到ACK报文,而重发FIN报文,所以这个TIME_WAIT状态的作用就是用来重发可能丢失的