Linux之操作文件的系统调用
目录
- 1.打开文件
- 参数介绍
- 2. 读文yXLlS件
- 3. 写文件
- 4.关闭
- 分析题
- 练习题
- 系统调用和库函数的区别
需要引入的头文件:
#inlcude<unistd.h>
1.打开文件
打开一个已存在的文件
int open(const char *pathname, int flags);
新建一个文件并创建权限
int open(const char *pathname, int flags, mode_t mode);
参数介绍
pathname:将要打开的文件路径和名称
flags:打开标志
标志介绍:
The argument flags must include one of the following access modes:
O_RDONLY, O_WRONLY, or O_RDWR. These request opening the file read-
only, write-only, or read/write, respectively.
O_RDONLY 只读打开
O_RDWR 读写打开
O_CREAT 文件不存在则创建
O_APPEND 文件末尾追加
O_TRUNC 清空文件,重新写入 mode
The following symbolic constants are provided for mode:
S_IRWXU 00700 user (file owner) has read, write, and execute permission
S_IRUSR 00400 user has read permission
S_IWUSR 00200 user has write permission
S_IXUSR 00100 user has execute permission
S_IRWXG 00070 group has read, write, and execute permission
S_IRGRP 00040 group has read permission
S_IWGRP 00020 group has write permission
S_IXGRP 00010 group has execute permission
S_IRWXO 00007 others have read, write, and execute permission
S_IROTH 00004 others have read permission
S_IWOTH 00002 others have write permission
S_IXOTH 00001 others have execute permission
返回值:文件描述符
2. 读文件
ssize_t read(int fd, void *buf, size_t count);
参数介绍
fd:对应打开的文件描述符buf : 存放数据的空间count: 计划一次从文件中读多少字节数据返回值: 实际读到的字节数
3. 写文件
ssize_t write(int fd, const void *buf, size_t count);
参数介绍:
fd :对应打开的文件描述符buf:存放待写入的数据count:计划一次向文件中写入多少数据
4.关闭
int close(int fd);
fd :对应的文件描述符
分析题
如果父进程先打开一个文件,fork 后子进程是否可以共享使用?
文件内容
代码
#include<stdio.h>
#include<unistd.h>
#include<assert.h>
#include<fcntl.h>
#include<stdlib.h>
int main()
{
char buff[128] = {0};
int fd = open("myfile.txt", O_RDONLY);
pid_t pid = fork();
assert(pid != -1);
if (pid == 0)
{
read(fd, buff, 1);
printf("child buff = %s\n", buff);
sleep(1);
read(fd, buff, 1);
printf("child buff = %s\n", buff);
}
else
{
read(fd, buff, 1);
printf("parent buff = %s\n", buff);
sleep(1);
read(fd, buff, 1);
printf("parent buff = %s\n", buff);
}
close(fd);
exit(0);
}
运行结果:
结论:
由于 fork 创建的子进程的 PCB 是拷贝父进程的,子进程的 PCB 中的文件表指向打开文件的指针只是拷贝了父进程 PCB 中的值,所以父子进程共享父进程 fork 之前打开的所有文件描述符。
练习题
完成对一个文件的复制(类似命令:cp)
原文件内容为:
代码:
#include<stdio.h>
#include<unistd.h>
#include<fcntl.h>
#include<stdlib.h>
#include<assert.h>
int main(void)
{
char buff[128] = {0};
int fdr = open("myfile.txt", O_RDONLY);
assert(fdr != -1);
int fdw = open("newfile.txt", O_WRONLY | O_CREAT, 0600);
assert(fdw != -1);
int n = 0;
while (n = read(fdr, buff, 128) > 0)
{
write(fdw, buff, n);
}
close(fdr);
close(fdw);
exit(0);
}
运行示例:
可以看到newfile.txt创建成功
系统调用和库函数的区别
区别: 系统调用的实现在内核中,属于内核空间,库函数的实现在函数库中,属于用户空间。
系统调用执行过程:
到此这篇关于linux之操作文件的系统调用的文章就介绍到这了,更多相关Linux文件系统调用内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341