文件读写是我们经常用到的, 各种编程语言都有自己的实现方式, 但是底层还是通过系统调用来实现, 有一些高级编程语言则是通过 C 语言系统调用来实现的
今天主要介绍下 C 语言实现文件读写
新建文件 main.c
代码如下:
由于代码排版可能会有问题, 所以有文字和图片两种形式
#include#include#include int main(int argc, char const *argv[]) {mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;int fd = open(argv[1], O_RDWR | O_EXCL | O_CREAT, mode);if (fd == -1) {perror("open");return EXIT_FAILURE;}return EXIT_SUCCESS;}
编译程序 gcc -o create main.c
之后会生成 create 可执行程序
运行如下: ./create test.txt
之后就会创建文本文档 test.txt
执行命令 ls -l
可以看到 test.txt 的访问权限是 -rw-r--r--
可以分为四组来看:
-
rw-
r--
r--
第一组 - 表示是否是目录
第二组 rw - 文件的所有者对文件有读写权限没有执行权限 rwx 中 x 代码执行权限
第三组和第四组表示只读权限
代码
mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;
为设置文件的访问模式
具体定义如下:
int fd = open(argv[1], O_RDWR | O_EXCL | O_CREAT, mode);
argv[1]为命令行传入参数, 就是文件名
O_RDWR | O_EXCL | O_CREAT
为打开模式
- /* open-only flags */#define O_RDONLY 0x0000 /* open for reading only */#define O_WRONLY 0x0001 /* open for writing only */#define O_RDWR 0x0002 /* open for reading and writing */#define O_ACCMODE 0x0003 /* mask for above modes */
- #define O_CREAT 0x0200 /* create if nonexistant */#define O_TRUNC 0x0400 /* truncate to zero length */#define O_EXCL 0x0800 /* error if already exists */
mode 为访问模式
open 函数为系统调用, 文件创建成功后会返回一个文件描述符失败会返回 - 1
程序启动时默认打开三个 I/O 设备文件: 标准输入文件 stdin, 标准输出文件 stdout, 标准错误输出文件 stderr, 分别得到文件描述符 0, 1, 2 所以文件创建成功后会返回文件描述符 3
接下来实现写文件, 新建文件 writefile.c
代码如下:
- #include#include#include#include#include#includeint main(int argc, char *argv[]) {int fd = -1, i;ssize_t size = -1;int input = 0;char buf[] = "this is a test";char *filename = argv[1];fd = open(filename, O_RDWR | O_TRUNC);if (-1 == fd) {printf("Open file %s failure,fd:%d", filename, fd);} else {printf("Open file %s success,fd:%d", filename, fd);}size = write(fd, buf, strlen(buf));printf("write %zd bytes to file %s", size, filename);close(fd);return 0;}
- fd = open(filename, O_RDWR | O_TRUNC);
已读写方式打开文件, 如果文件中有内容设置为 O_TRUNC 会清除里面内容
如果文件不存在返回 - 1
size = write(fd, buf, strlen(buf));
通过 write 系统调用写数据到文件中
接着看读文件, 新建文件 readfile.c
- #include#include#include#include#includeint main(int argc, char *argv[]) {int fd = -1, i;ssize_t size = -1;char buf[10];char *filename = argv[1];fd = open(filename, O_RDONLY);if (-1 == fd) {printf("Open file %s failure,fd:%d", filename, fd);} else {printf("Open file %s success,fd:%d", filename, fd);}while (size) {size = read(fd, buf, 10);if (-1 == size) {close(fd);printf("read file error occurs");return -1;} else {if (size > 0) {printf("read %zd bytes:", size);for (int i = 0; i < size; i++) {printf("%c", *(buf + i));}printf("");} else {printf("reach the end of file ");}}}return 0;}
- fd = open(filename, O_RDONLY);
以只读方式打开文件
size = read(fd, buf, 10);
每次读取 10 个字节
最后读取结果:
这些是 C/C++ 能做的
服务器开发工程师人工智能云计算工程师信息安全 (黑客反黑客) 大数据 数据平台嵌入式工程师流媒体服务器数据控解图像处理音频视频开发工程师游戏服务器分布式系统游戏辅助等
来源: http://www.jianshu.com/p/87e6d75f2919