c中的文件操作大致和linux的文件操作类似,但是毕竟是不同的API,所以会有些差异。部分差异会在下面的案例中体验
open的参数有两个一个是文件名,一个是模式选择,不同open函数,open中的模式是一个枚举mode_t, 这里的mode类型是一个字符中。
- #include
-
- FILE *fopen(const char *pathname, const char *mode);
open参数描述
pathname | 文件路径 |
mode | 模式,设置权限 |
mode
r | 以只读方式打开文件 |
r+ | 以读写方式打开文件 |
w | 清空文件或创建文件 |
w+ | 以读写方式打开文件,文件不存在会创建,如果存在会被截断 |
a | 以追加形式打开文件,文件不存在会创建,只能将内容添加到尾部 |
a+ | 以读写方式打开文件,并在文件后面追加,文件不存在会创建 |
返回值
指向文件流的FILE *指针类型,失败返回NULL
fopen 和open flag 转换表
close 比较简单,参数只一个打开的文件的描述符。成功返回0,失败返回EOF。
- #include
-
- int fclose(FILE *stream);
read函数尝试从stream 中 读取nmemb条数据,每条数据的大小为size,并把读取的数据放在ptr指针中。所以读取的数据大小 为 nmemb * size。
如果读取成功返回nmemb;
如果nmemb * size 超过文件的大小,返回的nmemb大小等于刚超过文件大小的值。比如文件中只有12345,size设置成3,nmemb如果设置成2,则返回2,如果设置超过2,也只能返回2。
nmemb: 可以理解为number of member block, 内存块的数量
- #include
-
- size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
write函数尝试向stream 中写入nmemb条数据,每条数据的大小为size,写入的数据放在ptr指针中。所以写入的数据大小为 nmemb * size。
如果写入成功返回nmemb;
如果nmemb * size 超过ptr缓冲区大小也能写入成功,也会返回nmemb。
- #include
-
- size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
-
重定位光标的位置。根据设置whence 来进行offset偏移,offset为负代码左偏移,为正代表右偏移。
成功返回0,失败返回-1; 通过调用ftell来获取当前光标的位置。而不是像lseek直接返回光标的位置。
- #include
- #include
-
- off_t lseek(int fd, off_t offset, int whence);
常用 whence
SEEK_SET | 定位到文件起始位置 |
SEEK_CUR | 定位到当前位置 |
SEEK_END | 定位到文件结束位置 |
argc: 代表参数数量 argument count
argv :代表argument vector ,是一个指针数组(数组元素类型是char *),或者说是一个二级指针(char **argv)
- #include
- #include
- #include
-
- int main(int argc, char *argv[]) {
- FILE *src, *des;
- char *readBuf = NULL;
- if(argc != 3) {
- printf("paramer error\n");
- exit(-1);
- }
-
- src = fopen(argv[1], "r");
- fseek(src, 0, SEEK_END);
- int size = ftell(src);
- fseek(src, 0, SEEK_SET);
-
- printf("size = %d", size);
- readBuf = (char *)malloc(sizeof(char) * size + 1);
- int readCount = fread(readBuf, size, 1, src);
-
- des = fopen(argv[2], "w+");
-
- fwrite(readBuf, strlen(readBuf), 1, des);
- fclose(src);
- fclose(des);
- return 0;
- }
-