IO相关的

什么是文件描述符,你是怎么理解的

文件描述符其实是一个指针数组的下标,每个进程都有独自的进程控制块task_struct,这里面有个指针指向一个files_struct,这个结构体里面有一个指针数组fd_array,这个指针数组的下标就是文件描述符,数组的每个元素指向一个struct_file,struct_file存储的是文件的信息,通过双链表组织起来的。

Linux系统下默认打开三个文件,分别是标准输入,标准输出,标准错误,它们的文件描述符分别是0,1,2。文件描述符是从最小但是没有被使用的fd_array数组下标开始进行分配的。

打开文件时,先把文件加载到内存,然后形成struct_file放入双链表里,把这个struct_file的地址填入fd_array下标为3的位置,最后返回文件描述符

文件描述符怎么分配的

文件描述符是从最小但是没有被使用的fd_array数组下标开始进行分配的。

Linux系统的文件io函数有什么,怎么使用

open函数,打开文件返回文件描述符

cpp 复制代码
int open(const char *pathname, int flags, mode_t mode);

pathname:文件名或者路径

flags:文件打开的方式,只读,只写。。。。

mode:文件权限,注意掩码

cpp 复制代码
int close(int fd);
cpp 复制代码
ssize_t write(int fd, const void *buf, size_t count);
cpp 复制代码
ssize_t read(int fd, void *buf, size_t count);

重定向的原理

原理就是修改文件描述符表中的指向,本来指向一个文件的,重定向之后,指向了另一个文件,其底层调用了dup2,来实现重定向

比如 ls > log.txt

本来是输出到屏幕的,重定向后输出到文件里了

其实就是调用dup2,把重定向文件的文件描述符的指针拷贝到1号描述符里,使得本来标准输出1号文件描述符指向显示器文件的,现在指向log文件了

dup2的原理

cpp 复制代码
int dup2(int oldfd, int newfd);

把文件描述符表里oldfd的内容拷贝到newfd里,这样使得newfd的指向发生改变了

标注输出和标准错误的区别

  • 文件描述符不同,标准输出是1,标准错误是2
  • 普通重定向对标准输出有用,标准错误没有用,标准错误要有特定的方式,比如 2 > log.txt
  • 缓冲机制不同,标准输出有行缓冲和全缓冲,标准错误没有

软硬链接的区别和使用场景

区别:

本质:硬链接是给原文件的inode新增一个文件名映射,同一个文件多个文件名。软连接是建立一个新的文件,文件内容是路径

inode号:硬链接是与原文件共享的。软连接是重新建立一个

连接对象:硬链接只能是文件,软连接可以是文件也可以是目录

删除操作:原文件删除之后不会影响硬链接。而对应软连接会导致连接失效

使用场景:

硬连接:

  • 用于文件备份
  • 不同目录下使用同一个文件,可以不用复制,使用硬链接,节省磁盘空间

软连接:

快捷方式:把长路径变成短路径

跨区访问时

相关推荐
Gorgous—l1 天前
数据结构算法学习:LeetCode热题100-动态规划篇(下)(单词拆分、最长递增子序列、乘积最大子数组、分割等和子集、最长有效括号)
数据结构·学习·算法
北京地铁1号线1 天前
2.3 相似度算法详解:Cosine Similarity 与 Euclidean Distance
算法·余弦相似度
Remember_9931 天前
【LeetCode精选算法】滑动窗口专题一
java·数据结构·算法·leetcode·哈希算法
Lueeee.1 天前
v4l2驱动开发
数据结构·驱动开发·b树
小饼干超人1 天前
详解向量数据库中的PQ算法(Product Quantization)
人工智能·算法·机器学习
你撅嘴真丑1 天前
第四章 函数与递归
算法·uva
漫随流水1 天前
leetcode回溯算法(77.组合)
数据结构·算法·leetcode·回溯算法
玄冥剑尊1 天前
动态规划入门
算法·动态规划·代理模式
mjhcsp1 天前
P14987 全等(mjhcsp)
算法·题解·洛谷
(❁´◡`❁)Jimmy(❁´◡`❁)1 天前
Atcoder abc441A~F 题解
算法·深度优先·图论