在linux中read、write函数
2013-12-02 09:09
169 查看
read函数从打开的设备或文件中读取数据。
#include<</span>unistd.h>
ssize_t read(int fd, void *buf, size_t
count);
描述:参数count是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。(注意:这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。)
返回值:若成功返回读到的字节数;若已到达文件结尾返回0;若出错返回-1;
注:有多种情况会出现实际读到的字节数少于要求读的字节数(count)。
●读普通文件时,在读到要求的字节数(count)之前已到达了文件尾端。
●从终端设备读,通常以行为单位,一次最多读一行,读到换行符就返回了。
●从网络读,根据不同的传输层协议和内核缓存机制,网络中的缓冲机构可能造成返回值可能小于请求的字节数。
write函数向打开的设备或文件中写数据.
#include<</span>unistd.h>
ssize_t write(int fd, const void *buf, size_t
count);
写常规文件时,write的返回值通常等于请求写的字节数count,而向终端设备或网络写则不一定。
返回值:若成功返回写入到设备或文件中的字节数;若失败返回-1;
#include<</span>unistd.h>
ssize_t read(int fd, void *buf, size_t
count);
描述:参数count是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。(注意:这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。)
返回值:若成功返回读到的字节数;若已到达文件结尾返回0;若出错返回-1;
注:有多种情况会出现实际读到的字节数少于要求读的字节数(count)。
●读普通文件时,在读到要求的字节数(count)之前已到达了文件尾端。
●从终端设备读,通常以行为单位,一次最多读一行,读到换行符就返回了。
●从网络读,根据不同的传输层协议和内核缓存机制,网络中的缓冲机构可能造成返回值可能小于请求的字节数。
write函数向打开的设备或文件中写数据.
#include<</span>unistd.h>
ssize_t write(int fd, const void *buf, size_t
count);
写常规文件时,write的返回值通常等于请求写的字节数count,而向终端设备或网络写则不一定。
返回值:若成功返回写入到设备或文件中的字节数;若失败返回-1;
相关文章推荐
- linux中memset的正确用法
- linux管道通信
- linux中open函数使用
- Windows mysql双向同步备份(适用linux)
- Deploy maven on Linux OS
- linux 里的一些英文缩写含义
- Ubuntu(Linux) 下 zip 命令使用详
- 查看linux发行版本方法
- Linux下常用命令
- 《鸟哥的Linux私房菜:基础学习篇》(高清第三版)
- Linux Crontab 定时任务 命令详解
- Linux内存点滴 用户进程内存空间
- Linux-根目录(/)的意义与内容
- Linux基础学习1
- Centos redmine最新版安装教程(redmine-2.4.1安装教程)
- Centos redmine最新版安装教程(redmine-2.4.1安装教程)
- linux查找命令和进程控制
- linux交叉工具链的安装
- Linux常用高级文件操作命令
- linux下vi编辑器命令大全