一、简介
1. open
头文件#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>
定义函数:
int open(const char * pathname, int flags);
int open(const char * pathname, int flags, mode_t mode);
函数说明:
第一个参数pathname 指向欲打开的文件路径字符串。
第二参数flags 所能使用的旗标:
1.O_RDONLY 只读打开。
2.O_WRONLY 只写打开。
3.O_RDWR 读、写打开。
4.O_APPEND 每次写时都加到文件的尾端。
5.O_CREAT 若此文件不存在则创建它。使用此选择项时,需同时说明第
第三个参数mode,用其说明该新文件的存取许可权位。
参数mode 则有下列数种组合, 只有在建立新文件时才会生效, 此外真正建文件时的权限会受到umask 值所影响, 因此该文件权限应该为 (mode-umaks).
S_IRWXU00700 权限, 代表该文件所有者具有可读、可写及可执行的权限.
S_IRUSR 或S_IREAD, 00400 权限, 代表该文件所有者具有可读取的权限.
S_IWUSR 或S_IWRITE, 00200 权限, 代表该文件所有者具有可写入的权限.
S_IXUSR 或S_IEXEC, 00100 权限, 代表该文件所有者具有可执行的权限.
S_IRWXG 00070 权限, 代表该文件用户组具有可读、可写及可执行的权限.
2.Read
定义函数ssize_t read(int fd, void * buf, size_t count);
使用的头文件:
#include <unistd.h>
函数的参数说明
【int fd】这个是文件指针
【void *buf】读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移
【size_t count】是请求读取的字节数。若参数count 为0, 则read()不会有作用并返回0. 返回值为实际读取到的字节数, 如果返回0
3.Write
定义函数ssize_t write (int fd, const void * buf, size_t count);
函数说明
write()会把参数buf 所指的内存写入count 个字节到参数fd 所指的文件内. 当然, 文件读写位置也会随之移动.
4.sleek
定义函数
off_t lseek(int fildes,off_t offset,int whence)
函数说明
每个已打开的文件都有一个读写位置,当打开文件通常的读写位置是指向文件的开头,若是以追加的方式打开(调用open 函数时使用了O_APPEND),则读写位置会指向文件末尾,当调用read()或creat()时,读写的位置随之增加;参数fildes为已打开的文件描述符,参数offset为根据参数whence来移动的读写位置的偏移量.文件指针的值等于当前指针的值加上offset的值。
1.SEEK_SET
-从文件开始处计算偏移量,文件指针到文件开始处的偏移量为offset.
2.SEEK_CUR
-从文件的指针的当前位置开始计算偏移量,文件指针值等于当前指针值加上offset的值,offset允许为负数.
3.SEEK_END
-从文件的结尾处计算偏移量,文件指针值等于当前指针的值加上offset的值.offset 允许取负数
二、实现文件的复制
#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/stat.h>#include <stdlib.h>#include <unistd.h>#include <fcntl.h>int main(int argc, const char* argv[]){int fd01 = open("english.txt", O_RDWR);//可读可写printf("fd01=%d\n", fd01);if (fd01 == -1){perror("Open failed");//错误代码写入errno,perror根据errno的数值显示相对应的错误}//打开另一个文件,若没有则建立int fd02 = open("test04", O_WRONLY | O_CREAT, 0777);printf("fd02=%d\n", fd02);//read读4Kchar buf[1024 * 2];//缓冲区int len = read(fd01, buf, sizeof(buf));//sizeof包含\0while (len > 0)//==0就是读完{int fd03 = write(fd02, buf, len);//写printf("fd03=%d", fd03);//文件指针再移动4k,继续读len = read(fd01, buf, sizeof(buf));}close(fd01);close(fd02);return 0;}
gcc system_func.c -o system_func./system_funcvim test04
结果显示:
三、文件的拓展(lseek)
#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/stat.h>#include <stdlib.h>#include <unistd.h>#include <fcntl.h>int main(int argc, const char* argv[]){int fd = open("english.txt", O_RDWR);if (fd == -1){perror("open error!");}//文件指针移到最后,再偏移1000int len = lseek(fd, 1000, SEEK_END);write(fd, "a", 1);//必须写入才生效close(fd);return 0;}
ll english.txtgcc lseekTest.c -o lseekTest./lseekTestll english.txt
结果显示:
说明:
系统显示全是乱码,其实全部是"\0",占位的作用。
如下载一个10G电影,刚开始就会在磁盘上先分配10G内存,先占位,怕后面别人占用。下载是多线程的,如1号指针负责前部分,2号指针负责后部分,占位后2号指针才能找到,才能移动过。