int open(char *pathname,int flag,/int mode/);
打开普通文件,pathname文件路径+文件名 flag打开方式 O_RDONLY O_WRONLY O_RDWR
失败返回-1 成功则返回打开的文件标识符
如果要设置多个选项,只要按位或就行
int read(int fd,void *buff,int size);
fd: open打开的文件标识符 buff:内存上一块缓冲区的起始地址,指定read读到内容的存储位置
size:缓冲区的大小,缓冲区的大小-1
失败返回-1,成功返回实际读到的字节数
int write(int fd,void *buff,int length);
fd: open打开的文件标识符 buff: 要写入数据的起始地址, length: 要写入的数据的实际长度
失败返回-1,,成功返回实际写入的值,大于等于0
int close(int fd);
关闭打开的文件,,fd: 已经打开的文件的文件标识符
int lseek(int fd,int size,int flag);
操作读写指针(读写偏移量)
fd :指定操作的文件标识符
size:移动的大小
flag:移动的相对位置-------------SEEK_SET SEEK_CUR SEEK_END
**需要清楚用户切换内核态的流程以及Linux系统内核打开文件的原理:
系统调用表:
系统调用号:
**
一个利用文件操作函数实现的cp命令拷贝代码
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include <fcntl.h>
/*
* 1、拷贝的源文件名 和 目标文件名
* ./mycp main.c test.c
* argv[0] argv[1] argv[2]
* */
int main(int argc, char *argv[])
{
if(argc < 3)
{
printf("error\n");
exit(0);
}
int fda = open(argv[1], O_RDONLY); // 以只读方式开打源文件
if(fda == -1)
{
printf("源文件打开失败\n");
exit(0);
}
int fdb = open(argv[2], O_CREAT | O_WRONLY | O_TRUNC, 0664); // 打开拷贝的目标文件
if(fdb == -1)
{
printf("目标文件打开失败\n");
close(fda); // 将之前打开的文件关闭
exit(0);
}
while(1)
{
char buff[128] = {0};
int n = read(fda, buff, 127);
if(n <= 0)
{
break;
}
write(fdb, buff, n);
}
close(fda);
close(fdb);
}