- 1、函数介绍
- 2、cp命令代码
1、open函数
int open(const char*pathname,int flags); int open(const char*pathname,int flags,mode_t mode); 参数: pathname 文件名 flags 以什么方式打开 mode 这个参数一般只有在创建文件的时候使用,设置文件权限 flags常用参数: O_RDonLY 读方式 打开 O_WRonLY 写的方式 打开 O_RDWR 读写方式 打开 O_APPEND 追加方式 打开 O_CREAT 要是文件不存在 则创建 O_EXCL 文件是否存在 O_TRUNC 截断内容 O_NonBLOCK 设置为非堵塞 mode参数: 文件权限 = mode & ~umask 返回值: 成功:0 失败:-1 设置errno
2、read函数
ssize_t read(int fd,void* buf,size_t count); 参数: fd 文件描述符 buf 存数据的缓冲区 count 缓冲区大小 返回值: 0 表示读到文件结尾 成功:读到字节数 失败:-1 设置errno 另外一种失败情况,-1 errno = EAGAIN 或 EWOULDBLOCK说明不是read读取失败,而是以非堵塞方式读取一个设备文件(网络),并且文件无数据
3、write函数
ssize_t write(int fd,const void* buf,size_t count); 参数: fd 文件描述符 buf 要写入数据 count 要写入的数据大小 返回值: 成功:写入字节数 失败:-1 设置errno
strace 命令运行程序的系统调用
fgetc和write函数都是每次只读一个字节,谁的效率高
1、 绝对是fgetc,因为fgetc有用户缓冲区,先把数据读到用户缓冲区,然后在进内核缓冲区,再把内核缓冲区数据写到磁盘中
2、而write是每次读一个字节数据,就进入一次内核,把数据写入内核缓冲区,然后写入磁盘,进内核是很花费时间的,因为fgetc进入的次数少,他的效率肯定会高一些
2、cp命令代码read、write 函数常常被称为Unbuffered IO,指的是无用户及缓冲区,但不保证不适用内核缓冲区
#include#include #include #include #include #define N 1024 int main(int argc,char* argv[]) { int fd1 = open(argv[1],O_RDONLY); // 读的方式打开被拷贝文件 if(fd1==-1) { perror("open argv1 error"); exit(1); } // 如果文件存在就清空内容,然后拷贝,不存在则创建,并设置权限 int fd2 = open(argv[2],O_RDWR | O_CREAT|O_TRUNC,0664); char* buf[N]; int n =0; // 读取被拷贝文件中的内容 while(n=read(fd1,buf,N)) { if(n<0) { perror("read error"); exit(1); } // 写入需要拷贝的文件中 write(fd2,buf,n); } close(fd1); close(fd2); return 0; }



