默认情况下,read函数是阻塞的。这意味着如果调用read时数据尚未准备好,进程会被挂起,直到有数据可读为止。read函数的原型如下: c ssize_t read(int fd, void *buf, size_t count); fd:文件描述符,标识要读取数据的文件或设备。 buf:指向存储读取数据的缓冲区的指针。 count:要读取的字节数。 如果read成功读...
read函数只是一个通用的读文件设备的接口。是否阻塞需要由设备的属性和设定所决定。一般来说,读字符终端、网络的socket描述字,管道文件等,这些文件的缺省read都是阻塞的方式。如果是读磁盘上的文件,一般不会是阻塞方式的。但使用锁和fcntl设置取消文件O_NOBLOCK状态,也会产生阻塞的read效果。
在默认情况下,read函数是阻塞的。即,当调用read函数时,如果没有数据可供读取,它将会阻塞住并等待数据的到来。一旦有数据到来,read函数将会返回读取到的字节数,然后程序继续执行。 阻塞模式对于某些场景来说是非常有用的,特别是在需要精确控制数据的读取速度时。例如,当从标准输入读取用户的输入时,我们希望程序能够暂...
读常规文件是不会阻塞的,不管读多少字节,read一定会在有限的时间内返回。从终端设备或网络读则不一定,如果从终端输入的数据没有换行符,调用read读终端设备就会阻塞,如果网络上没有接收到数据包,调用read从网络读就会阻塞,至于会阻塞多长时间也是不确定的,如果一直没有数据到达就一直阻塞在那里。同样,写常规文件是不会...
read函数是Linux下不带缓存的文件I/O操作函数之一,所谓的不带缓存是指一个函数只调用系统中的一个函数。另外还有open、write、lseek、close,它们虽然不是ANSI C的组成部分,但是POSIX的组成部分。 在对read的使用过程中,发现对其返回值的处理比较重要,这里做一下总结。
1. read函数是一个阻塞函数,即在读取数据时会一直等待,直到有数据可读或者出错。可以通过设置文件描述符的属性为非阻塞模式来避免阻塞。 2. read函数可能会读取比count指定的字节数少的数据,需要多次调用read函数直到读取到count个字节的数据为止。 3. read函数读取的数据会保存到buf中,需要保证buf足够大以容纳读取的...
对于read,block指当串口输入缓冲区没有数据的时候,read函数将会阻塞在这里,移植到串口输入缓冲区中有数据可读取,read读到了需要的字节数之后,返回值为读到的字节数; 对于write,block指当串口输出缓冲区满,或剩下的空间小于将要写入的字节数,则write将阻塞,一直到串口输出缓冲区中剩下的空间大于等于将要写入的字节数...
不知题主的read是指socket的read还是文件的read。默认情况下,socket的read是阻塞的;对文件进行read,要看内核态的read接口是注册为同步接口还是异步接口(可参见file_operations结构体)