Linux---软硬链接

软链接

我们先学习一下怎样创建软链接文件,指令格式为:ln -s 被链接的文件 生成的链接文件名

我们可以这样记忆:ln是link的简称,s是soft的简称。

我们在下面的图片中就是给test文件生成了一个软链接mytest:

我们来解释一下图片上每一行中各部分的意义:

在使用ls命令时,加上-i的选项就可以在第一行查看文件的inode,这里我们可以看到我们的软链接文件和原本的文件的inode不同,也就是说我们的软链接文件有自己的inode,并且软链接文件和原有文件的属性也不一致,例如我们原本文件权限为0664,文件大小为0,我们的软链接文件权限则为0777,文件大小为4。这说明我们创建软链接文件时操作系统会给我们创建一个新的文件,这个文件有自己的属性和inode,但是如果我们执行这两个文件的话,二者的执行结果是一致的。例如我们将test编译成一个打印"hello world"的程序。执行两个文件得:

软链接的应用

其实软链接就类似于windows下的快捷方式,可以便利我们的使用。例如一个情况:我们在其他目录下有一个文件需要在当前目录下调用,如果不用软链接的话,我们就需要./一串路径来调用,很麻烦,如果我们使用软链接的方式连接到该可执行文件,就很方便了。例如下面的代码:

我们在当前目录下,创建一连串目录,在最里面的子目录创建了一个可执行文件love,他的功能是打印一个study。如果我们想在当前目录下执行love的话,我们就需要带上一长串路径,但是我们创建一个软链接链接到love的话,我们只需要执行链接文件即可。这就是软链接的作用。

硬链接

相比软链接,硬链接要说的知识会多很多。

我们先来看创建硬链接的操作:ln 原文件名  链接文件名

也就是我们创建链接文件时不加-s,创建的链接文件就是硬链接文件,如下图:

我们仔细观察会发现硬链接于与软链接的不同:

红色圈住的是文件的inode,我们可以看到原文件和硬链接文件inode一致,软硬链接最根本的区别就是:是否有各自独立的inode。绿色的是文件的硬链接数,也就是有几个文件名对应这一个inode,硬链接数为2,也就代表有两个文件名指向了这同一个inode。

我们一对比就能发现:软链接有属于自己的inode,所以软链接是一个独立的文件。而硬链接并没有独立的inode,所以他并不能被当作独立的文件看待。在创建硬链接文件时,并没有创建新文件,因为他并没有分配独立的inode,他用的是原文件的inode和内容。我们在上篇文章讲过目录的数据块记录着文件名和inode的映射关系,创建硬链接的本质就是在目录的数据块中添加一个文件名,并使这个文件名指向原文件的inode,所以一个inode可能会被多个文件名所指向。因此为了记录一个inode被多少个文件名所指,在inode内有一个计数器,当有一个文件名指向该inode时,计数器加1,这个就是我们的硬链接数,也就是我们上图中绿色圈住的部分。

既然链接文件名和原文件名都指向同一个inode,我们可以试着删除掉其中一个文件,看看会发生什么,这里我们把原文件删掉,结果如下:

我们会发现软链接文件mytest标红,一直闪烁着红色表示警告。而对硬链接文件来说,并没有受什么影响,功能及属性都没变,只有硬连接数变了,由2变为了1,也就是说我们刚才删除了原文件并不是真的删除了文件,而是将目录数据块中记录的原文件名字与inode映射关系删除了,硬链接文件名和inode的映射关系仍在。只有当一个文件的硬连接数为0才是真正的删除了一个文件,其余的只是删掉一个映射关系,计数器减一。

这也侧面说明了软链接不是通过inode找到文件的,而是通过文件名来找文件的,由于文件之间都是树状结构连接起来的,在树状结构中查找一个文件名的方式是通过绝对路径或相对路径,所以软链接文件的数据块中保存的是原文件的路径,这也就是问什么删除原文件名软链接会发警报的原因。

硬链接的补充

我们会发现创建一个普通文件时,硬连接数都是1,这很正常没问题。但是在创建一个目录文件时,硬链接数是2,而且若在目录下再创建目录文件的话,多创建一个目录文件,上层目录的硬链接数就会加1。原因就是创建目录文件时,目录文件下会自动生成 ...两个隐藏文件。

这里bin是一个目录文件,其下就会有.和..两个文件,其中.指向目录自己,..指向目录的上层目录。

其实就是.文件映射的inode也是目录自己的inode,..文件映射的inode是上层目录的inode。所以硬连接数就会增加。

硬链接的目的

就是让多个不在同一目录下或者在同一目录下的文件,能够同时修改同一文件,其中一个修改后,所有与其硬连接的文件一起修改了。

文件的三个时间

我们可以通过 stat 文件名 的方式查看对应文件的信息:

信息中包含了三个时间:

  1. Access: 文件最后被访问的时间。
  2. Modify: 文件内容最后的修改时间。
  3. Change: 文件属性最后的修改时间。

当我们修改文件内容时,文件属性一般也会修改,所以modify修改时也会带着change时间一起修改。至于access时间,在以前老版本的时候,是只要访问文件后,该时间就会修改。但是在实际中访问文件的场景比修改文件的场景多很多,每次访问文件都要修改时间的话就很拉低效率,例如:我们总是cat一个文件,如果每次cat后都要更新时间的话真的太浪费时间了,所以在Linux2.6以后,只有真正的有效访问或者多次访问后才会刷新。

在我们使用make和makefile的时候,make会主动检测源文件是否做了修改,如果源文件没有被修改就不会重新编译,其中make就是通过文件的modify更改时间来判断源文件是否做了修改,若做了修改,源文件的修改时间是会比可执行文件的修改时间晚的。这就是时间在make上所做的应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/592130.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构篇其四---栈:后进先出的魔法世界

前言 栈的学习难度非常简单,前提是如果你学过顺序表和单链表的话,我直接说我的观点了,栈就是有限制的顺序表和单链表。 栈只允许一端进行插入删除。栈去除了各种情况复杂的插入删除,只允许一端插入删除的特性,这一种数…

5月4(信息差)

🎄 HDMI ARC国产双精度浮点dsp杜比数码7.1声道解码AC3/dts/AAC环绕声光纤、同轴、USB输入解码板KC33C 🌍 国铁集团回应高铁票价将上涨 https://finance.eastmoney.com/a/202405043066422773.html ✨ 源代码管理平台GitLab发布人工智能编程助手DuoCha…

【数据结构】您有一份KMP算法教学已到账,请注意查收!!!

KMP算法 导读一、KMP算法1.1 重要术语1.2 部分匹配值1.3 部分匹配值的作用 二、KMP算法原理2.1 从指针的角度理解KMP算法2.2 从匹配的角度理解KMP算法2.3 小结 三、KMP算法的实现3.1 next数组3.2 next数组的计算3.2.1 通过PM值计算next数组3.2.2 通过移位模拟计算next数组3.2.3…

Web Storage 笔记11 网页数据存储

相关内容:Web Storage基本概念、localStorage、sessionStorage、登录注销实例、…… 在制作网页时会希望记录一些信息,例如用户登录状态、计数器或者小游戏等,但是又不希望用到数据库,就可以利用WebStorage技术将数据存储在用户浏…

Kubelet containerd 管理命令 ctr常用操作

镜像常用操作 1. 拉取镜像 ctr images pull docker.io/library/nginx:alpine 指定平台 --all-platforms:所有平台(amd64 、arm、386 、ppc64le 等),不加的话下载当前平台架构 --platform:指定linux/amd64平台 ctr …

鸿蒙开发仿咸鱼TabBar

鸿蒙开发自定义TabBar,实现tabBar 上中间按钮凸起效果 第一步、定义数据模型 export default class TabItemData{defaultIcon: ResourceselectedIcon: Resourcetitle: stringisMiddle: booleanconstructor(defaultIcon:Resource, selectedIcon:Resource, title:st…

并发-启动线程的正确姿势

目录 启动线程的正确姿势 Start方法原理解读 Run方法原理解读 常见问题 启动线程的正确姿势 start()与run()方法的比较测试结果可以看出,runnable.run()方法是由main线程执行的,而要子线程执行就一定要先调用start()启动新线程去执行run方法并不能成…

【数据结构】第四讲:双向链表

目录 一、链表的分类 二、双向链表的结构及实现 1.带头双向链表的结构 2.创建节点 3.初始化 4.尾插 5.打印 6.头插 7.尾删 8.头删 9.在pos位置之后插入数据 10.删除pos节点 11.查找 12.销毁 个人主页:深情秋刀鱼-CSDN博客 数据结构专栏:数…

Mac M2 本地下载 Xinference

想要在Mac M2 上部署一个本地的模型。看到了Xinference 这个工具 一、Xorbits Inference 是什么 Xorbits Inference(Xinference)是一个性能强大且功能全面的分布式推理框架。可用于大语言模型(LLM),语音识别模型&…

激动,五四青年节,拿下YashanDB认证YCP

📢📢📢📣📣📣 作者:IT邦德 中国DBA联盟(ACDU)成员,10余年DBA工作经验, Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主,全网粉丝10万 擅长主流Oracle、My…

中间件之搜索和数据分析组件Elasticsearch

一、概述 1.1介绍 The Elastic Stack, 包括 Elasticsearch、Kibana、Beats 和 Logstash(也称为 ELK Stack)。 能够安全可靠地获取任何来源、任何格式的数据,然后实时地对数据进行搜索、分析和可视 化。Elaticsearch,简称为 ES&a…

CUDA和显卡驱动

1.安装显卡驱动 https://www.nvidia.com/download/index.aspx?langen-us 由于我的显卡是RTX4060,因此先选择RTX40系列,然后选择RTX4060,进行安装 2.查看显卡对应的CUDA CUDA安装地址:https://developer.nvidia.com/cuda-toolk…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-12-蜂鸣器

前言: 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM(MX6U)裸机篇”视频的学习笔记,在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

复旦微JFM7VX690计算后IO接口模块,用于雷达信号处理、数据处理等需要高速密集计算的应用场景

计算后IO接口模块 1 介绍 1.1 产品概述 计算后IO接口模块主要由复旦微JFM7VX690型FPGA、国产以太网收发器YT8521、国产BMC芯片GD32F450、国产CPLD芯片EF2L45BG256B、国产内存颗粒等主要芯片组成,采用标准6U VPX尺寸设计。 本计算后IO接口模块主要用于雷达信号处…

QT+串口调试助手+基本版

一、创建串口调试助手UI界面 1、首先生成串口连接必要参数界面,删除关闭串口控件 2、给参数下拉框添加常见的选项,删除关闭串口控件 3、将串口调试助手参数界面布局整齐,删除关闭串口控件 4、更改控件名字,方便后续编程&#xff…

第五篇:通信脉络:探索计算机外设与总线体系的精髓

通信脉络:探索计算机外设与总线体系的精髓 1 引言 在这个技术日新月异的时代,理解计算机系统的基本构成要素 —— 总线和外设 —— 对于每个从事技术工作的人来说都是至关重要的。这些组件不仅是计算机通信的基石,也直接影响着系统的性能、效…

Universal Thresholdizer:将多种密码学原语门限化

参考文献: [LS90] Lapidot D, Shamir A. Publicly verifiable non-interactive zero-knowledge proofs[C]//Advances in Cryptology-CRYPTO’90: Proceedings 10. Springer Berlin Heidelberg, 1991: 353-365.[Shoup00] Shoup V. Practical threshold signatures[C…

关于MS-DOS时代的回忆

目录 一、MS-DOS是什么? 二、MS-DOS的主要功能有哪些? 三、MS-DOS的怎么运行的? 四、微软开源MS-DOS源代码 五、高手与漂亮女同学 一、MS-DOS是什么? MS-DOS(Microsoft Disk Operating System)是微软公…

多线程与信号量简介

信号量与 PV 操作 计算机中信号量的本质是整数,数值表示可用的资源数量 P 操作 (Passeren > 通过, 原子操作) 若信号量 0,当前任务阻塞 (进入信号量等待队列)若信号量 > 0,则:将信号量数值减一,当前任务继续执…

USP技术提升大语言模型的零样本学习能力

大语言模型(LLMs)在零样本和少样本学习能力上取得了显著进展,这通常通过上下文学习(in-context learning, ICL)和提示(prompting)来实现。然而,零样本性能通常较弱,因为缺…
最新文章