recv和recvfrom都是用来接受来自的网络的数据。...来看看它们的原型: int recv( SOCKET, char FAR*, int, int ); int recvfrom( SOCKET, char FAR*, int, int, struct...在linux下面的定义只是将SOCKET改成int,那么在linux下面的原型是这样: int recv( int, char FAR*, int, int ); int recvfrom( int,...因为还是有点小区别,linux下面是int类型,而windows下面是unsigned int。...如果套接字为阻塞的,在系统缓冲中没有数据的情况下,都将阻塞;如果套接字为非阻塞的,在系统缓冲中没有数据的情况下,都将立即返回,返回值在linux 下为-1, errno被设置为EWOULDBLOCK,在
socket有个recv方法,recv有一个参数,指定数据缓冲区的大小 但是现在的问题就是不知道将要接受的数据的大小到底是多少,可能只有几个字节,可能会有几M,google了一下socket的入门文章似乎都理所当然的指定
(这里是windows中的头文件,Linux的用法在下面的那个实例) 头文件:#include #include int recvfrom...2、recv() 头文件:#include #include 定义函数:int recv(int s, void *buf,...int len, unsigned int flags); 函数说明:recv()用来接收远端主机经指定的socket 传来的数据, 并把数据存到由参数buf 指向的内存空间, 参数len...其他数值定义如下: 1、MSG_OOB 接收以out-of-band 送出的数据. 2、MSG_PEEK 返回来的数据并不会在系统内删除, 如果再调用recv()会返回相同的数据内容.
之前写代码的时候, 发现socket的 recv 函数一直返回空字符串。 感觉很是奇怪,自己没有去设置阻塞模式,也就是默认的阻塞模式,为什么不阻塞在那里,而是要一直收到空呢?...socket.recv(bufsize[, flags]) Receive data from the socket....See the Unix manual page recv(2) for the meaning of the optional argument flags; it defaults to zero
Linux设备驱动中的阻塞和非阻塞I/0,简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的支持用户空间对设备的这两种访问方式。...非阻塞应用程序通常使用select系统调用查询是否可以对设备进行无阻塞的访问最终会引发设备驱动中 poll 函数执行。...=1); //串口上没有输入则返回,所以循环读取 printf("%c/n",buf); 阻塞操作常常用等待队列来实现,而非阻塞操作用轮询的方式来实现。...非阻塞I/O的操作在应用层通常会用到select()和poll()系统调用查询是否可对设备进行无阻塞访问。select()和poll()系统调用最终会引发设备驱动中的poll()函数被调用。...return mask; } 三、总结 阻塞与非阻塞操作: 定义并初始化等待对列头; 定义并初始化等待队列; 把等待队列添加到等待队列头 设置进程状态(TASK_INTERRUPTIBLE(可以被信号打断
非阻塞connect详情介绍可以参见文章:https://blog.csdn.net/qq_41453285/article/details/89890429 一、非阻塞connect概述 man手册...解析文档,非阻塞connect如何使用: ①当我们将sock设置为非阻塞之后,使用connect去连接服务端,即使服务端开启了,connect系统调用也不会连接成功,connect而是以失败告终,并返回错误...②但是非阻塞connect返回的错误是有讲究的: 如果非阻塞connect返回的错误是EINPROGRESS,代表不是connect系统调用出错了,而是connect可能会在后面才会建立完整地连接(...,进一步来等待非阻塞connect客户端与服务端建立完整地连接,在等待的过程中,如果非阻塞connect建立成功了,客户端的sock_fd就会变成可写的(这个在本人的IO复用文章中介绍过,见下图) ④当非阻塞...在有些系统(比如Linux)上返回-1,而在有些系统上(比如源自伯克利的UNIX)返回0 这些问题没有一个统一的解决办法 三、编码演示案例 #include #include <stdlib.h
如果任意时刻调用wait/waitpid,子进程存在且正常运行,则可能阻塞。 如果不存在该进程,则立即出错放回。...sleep(5); exit(257); } else { //father int status = 0; pid_t ret = waitpid(-1,&status,0);//阻塞等待...{ //father int status = 0; pid_t ret = 0; do { ret = waitpid(-1,&status,WNOHANG);//非阻塞等待...3.解释堵塞与非堵塞 阻塞场景:打电话等朋友接听 你拨打朋友的电话,直到朋友接通之前你什么都做不了。这就像阻塞调用,你必须等着事情完成。...非阻塞场景:发消息等待回复 你给朋友发了个消息,等他们回你。你不用一直盯着手机看,而是可以去做别的事情,等收到消息后再查看。这就像非阻塞调用,你不需要等着完成才能做其他事情。
大部分高性能网络框架采用的是非阻塞模式。笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。...本文源码均来自采用Linux-2.6.24内核版本。...\非阻塞状态 我们用fcntl修改socket的阻塞\非阻塞状态。...的时候 我们跟踪源码调用: socket.recv |->sys_recv |->sys_recvfrom |->sock_recvmsg |->__sock_recvmsg...希望笔者这篇文章能帮助到阅读linux网络协议栈代码的人。
阻塞。 好吧,再来一点营养。阻塞是啥意思呢? 就是水管堵住了!扭开水龙头没有水出来。...这个道理跟Linux下读取慢速设备(主要指管道和套接字)数据的情形非常相似,例如当我们在读取一个管道时,如果管道里面没有数据,那么我们什么都读不出来,于是就进入了所谓的“阻塞”状态了,说白了阻塞就是使得当前进程或者线程睡眠了的意思...那么再进一步,什么时候会阻塞呢?下面的表格简单描述了这些清空: ? 其中,读者指的是对管道文件拥有读权限的进程或线程(注意不是正在读),写者指的是对管道文件拥有写权限的进程或线程(注意不是正在写)。...除此之外,其实open()函数也会发生阻塞,比如用只读或者只写open一个管道文件的时候。因为一根只有出口或者只有入口的水管,是无法使用的呀!其实就是生活常识。嘿嘿!
从linux源码看socket的阻塞和非阻塞 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。 大部分高性能网络框架采用的是非阻塞模式。...笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。 本文源码均来自采用Linux-2.6.24内核版本。...\非阻塞状态 我们用fcntl修改socket的阻塞\非阻塞状态。...的时候 我们跟踪源码调用: socket.recv |->sys_recv |->sys_recvfrom |->sock_recvmsg |->__sock_recvmsg...阻塞后什么时候恢复运行呢 情况1:有对应的网络数据到来 首先我们看下网络分组到来的内核路径,网卡发起中断后调用netif_rx将事件挂入CPU的等待队列,并唤起软中断(soft_irq),再通过linux
而recv和send函数就是对这两个函数进行操作。...一、recv函数 int recv( SOCKET s, char *buf, int len, int flags); 函数功能:不论客户端还是服务端都能通过recv从TCP另一端接收数据。...函数的执行流程:当应用程序调用recv函数时,recv先等待s的发送缓冲中的数据被协议传送完毕,(发送先) 如果协议在传送s的发送缓冲中的数据时出现网络错误,那么recv函数返回SOCKET_ERROR...,recv函数就把s的接收缓冲中的数据copy到buf中(注意协议接收到的数据可能大于buf的长度,所以在这种情况下要调用几次recv函数才能把s的接收缓冲中的数据copy完。...recv函数仅仅是copy数据,真正的接收数据是协议来完成的),recv函数返回其实际copy的字节数; 如果recv在copy时出错,那么它返回SOCKET_ERROR;如果recv函数在等待协议接收数据时网络中断了
recv函数 int recv( SOCKET s, char FAR *buf, int len, int flags ); 不论是客户还是server应用程序都用recv函数从...当应用程序调用recv函数时,recv先等待s的发送缓冲 中的数据被协议传送完成,假设协议在传送s的发送缓冲中的数据时出现网络错误,那么recv函数返回SOCKET_ERROR,假设s的发送缓冲中没有数...recv函数仅仅是copy数据,真正的接收数据是协议来完成的),recv函数返回事实上际copy的字节数。...假设recv在copy时出错,那么它返回SOCKET_ERROR;假设recv函数在等待协议接收数据时网络中断了,那么它返回0。...注意:在Unix系统下,假设recv函数在等待协议接收数据时网络断开了,那么调用recv的进程会接收到一个SIGPIPE信号,进程对该信号的默认处理是进程终止。
在Linux系统中,I/O操作可以分为两种模式:阻塞式I/O和非阻塞式I/O。 这两种模式决定了进程在执行I/O操作时的行为方式,以及CPU资源的利用效率。...2 非阻塞式 I/O (Non-blocking I/O) 非阻塞I/O则是在执行I/O操作时,不管资源是否可用,操作系统都不会让进程进入阻塞状态,而是立即返回控制权。...4 阻塞与非阻塞 I/O 的优缺点 阻塞式 I/O 优点: 程序结构简单,不需要处理I/O状态的变化。 在I/O等待时,能够让出CPU资源,提高系统整体的CPU利用效率。...阻塞式 I/O 缺点: 由于进程可能长时间阻塞,会降低系统的响应性。 不适合高并发场景,因为每个阻塞的进程都会占用一个线程或进程资源。...以鼠标输入设备文件为例,Linux中鼠标对应的设备文件通常位于/dev/input/目录下,命名为mouseX(X为序号)或eventX。
2.recv函数 ssize_t recv(int s, char *buf, size_t len, int flags); (1)recv先等待s的发送缓冲中的数据被协议传送完毕,如果协议在传送s的发送缓冲...recv函数仅仅是copy数据,真正的接收数据是协议来完成的) (3)recv函数返回其实际copy的字节数。...如果recv在copy时出错,那么它返回SOCKET_ERROR;如果recv函数在等待协议接收数据时网络中断了,那么它返回0。...注意:在Unix系统下,如果recv函数在等待协议接收数据时网络断开了,那么调用recv的进程会接收到一个SIGPIPE信号,进程对该信号的默认处理是进程终止。...Q&A: (1)两次send一次recv会发生什么? 一次性读取两次send的内容。 (2)recv之后,接收缓冲区会被清空吗? 是的。
学Linux网络编程这么久,还真没注意到 read/write 和 recv/send之间有什么区别,于是就去研究了一下。...首先呢,recv/send 的第一个参数 socket s (int s)起这么个名字就已经能说明问题了吧,这俩函数也确实一般用于网络通信。...其次,就是 recv/send 相较于 read/write 这多出的第四个参数,以前都是说,默认填个0就好了,但是一直不知道为什么。...int flags); flags取值有: 0: 与write()无异 MSG_DONTROUTE:告诉内核,目标主机在本地网络,不用查路由表 MSG_DONTWAIT:将单个I/O操作设置为非阻塞模式...MSG_DONTWAIT:将单个I/O操作设置为非阻塞模式 MSG_OOB:指明发送的是带外信息 MSG_PEEK:可以查看可读的信息,在接收数据后不会将这些数据丢失 MSG_WAITALL:通知内核直到读到请求的数据字节数时
客户端的程序连接上服务器后recv函数阻塞接受,有时会返回0,说明接收超时服务器主动断开了连接,需要重新connect服务器,但重新connect时会报“Transport endpoint is already...是否要在 recv之前,判定连接是否中断,如果未中断则recv. 恩。我最后查了一下,是因为服务端关闭了套接字,才导致这边recv返回0。...默认 socket 是阻塞的 解阻塞与非阻塞recv返回值没有区分,都是 0 接收到数据大小, 特别: 返回值阻塞模式下recv会阻塞着接收数据,非阻塞模式下如果没有数据会返回,不会阻塞着读,因此需要循环读取)。 返回说明: 成功执行时,返回接收到的字节数。 另一端已关闭则返回0。...失败返回-1, errno被设为以下的某个值 EAGAIN:套接字已标记为非阻塞,而接收操作被阻塞或者接收超时 EBADF:sock不是有效的描述词 ECONNREFUSE:远程主机阻绝网络连接
摘要 在linux下,使用socketpair函数能够创建一对套节字进行进程间通信(IPC)。...include int socketpair(int domain, int type, int protocol, int sv[2]); 参数1(domain):表示协议族,在Linux...(自从Linux 2.6.27后也支持SOCK_NONBLOCK和SOCK_CLOEXEC) 参数2(type):表示协议,可以是SOCK_STREAM或者SOCK_DGRAM。...注意: 1、该函数只能用于UNIX域(LINUX)下。 2、只能用于有亲缘关系的进程(或线程)间通信。...4、在读的时候,管道内必须有内容,否则将会阻塞;简而言之,该函数是阻塞的。
首先来看一个跟read 相似的系统函数recv。 ...#include #include ssize_t recv(int sockfd, void *buf, size_t len, int...flags); recv函数与read函数类似,但只能读取套接字描述符,而不能是一般的文件描述符,且多了一个标志参数。...下面使用封装后的recv函数实现readline函数: /* recv()只能读写套接字,而不能是一般的文件描述符 */ ssize_t recv_peek(int sockfd, void *buf,...参考: 《Linux C 编程一站式学习》 《TCP/IP详解 卷一》 《UNP》
阻塞与非阻塞 应用进程请求I/O操作时,如果数据未准备好,如果请求立即返回就是非阻塞,不立即返回就是阻塞。简单说就是做一件事如果不能立即获得返回,需要等待,就是阻塞,否则就可以理解为非阻塞。...阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。有人也许会把阻塞调用和同步调用等同起来,实际上它们是不同的。...socket接收数据的另外一个函数recv则是一个阻塞调用的例子。当socket工作在阻塞模式的时候, 如果没有数据的情况下调用该函数,则当前线程就会被挂起,直到有数据为止。...非阻塞 非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。...同步/异步与阻塞/非阻塞的组合 同步阻塞形式: 等待执行结果是一直等待,执行时线程挂起(未对fd 设置O_NONBLOCK 标志位的read/write 操作) 同步非阻塞形式:等待执行结果是一直等待,
以调用函数为例, 同步指的是调用方主动查询返回结果,异步是等待被调用方通知查询结果 阻塞是等待返回结果的时间内挂起,非阻塞是等待返回结果的时间内可以干其他事情....同步和阻塞完全不是一件事,是否同步指的是获取返回结果的方式,是否阻塞指的是等待获取结果的时间内是否可以干其他事情
领取专属 10元无门槛券
手把手带您无忧上云