位置: 编程技术 - 正文

Unix文件系统和pwd命令实现详解(unix的文件系统采用)

编辑:rootadmin

推荐整理分享Unix文件系统和pwd命令实现详解(unix的文件系统采用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:unix中文件系统采用,unix中文件系统采用,unix操作系统的文件系统,unix操作系统的文件系统,unix中的文件系统采用,unix操作系统的文件系统,unix的文件系统采用,unix操作系统的文件系统,内容如对您有帮助,希望把文章链接给更多的朋友!

1. 对于用户来讲Unix系统中硬盘上的文件组成一棵目录树。每个目录能包含文件和其他子目录。

目录树的深度几乎没有限制,当然如果你所创建的目录树太深,系统就会提醒超过范围,并停止执行,以下脚本经测试有效

while true

do

mkdir deep_well

cd deep_well

done

我运行了几秒后,中断系统提示超过目录树范围。

2. 一个磁盘可以划分为N多扇区,每个扇区有字节 。扇区是磁盘上的基本存储单元,我们可以将每个扇区进行编号,这样磁盘就变为

一系列编了号的块的组合。

3. 磁盘块上存储文件时,按照一定的规律。

每个文件系统分为3部分:超级块,i-节点表,数据区 。

超级块 :存放文件系统本身的信息,比如记录了每个区域的大小,或未被使用的磁盘块的信息。(不同版本稍有差别)

i-节点表 :每个文件都有其属性,大小,最近修改时间等等,这些被存储在ino_t 的结构体中,所有的i-节点都有一样的大小,i-节点表就是这样一些节点的列表。

(表中的每个i-节点都通过位置来标志,例如标志为2的i-节点位于文件系统i-节点表中的第3个位置 )

数据块 :存放文件内容,因为块的大小一定,所以有时一个文件会分布在多个磁盘上。

4. 创建一个文件的4个步骤:

存储属性:内核先找到一个空的i-节点,把文件的属性信息填入其中;

存储数据:从磁盘上找出空闲块,把文件数据复制进去;

记录分配情况:内核在i-节点的磁盘分布区记录了刚刚的磁盘编号

添加文件名到目录:将(i-节点号,文件名)添加到目录。

5. cat,more等一些命令的实现思想:

cat name

在目录中寻找文件名,

定位到相应文件名的i-节点号;

根据i-节点号里面获得文件属性,查看权限,若权限不够则open()函数返回1,打开失败,停止;

根据i-节点里面磁盘位置访问文件位置的数据块

一遍遍调用read读取数据(可以存放到缓冲区)

6. 大文件的存储

如果一个文件需要个编号的磁盘块来存储,但是i-节点值包含个项的分配链表,这时候,我们可以将前个放到i-节点里,其他4个放到一个数据块里面,在i-节点的第

位写上指向存那4个编号的块。则我们实际用了+4+1个数据块,那个多出来的叫:间接块 。

同理,间接块饱和时,我们可以设置二级间接块,,,

7. 文件在目录中的含义

目录包含(i-节点号,文件名)的入口,即目录包含的是文件的引用,每个应用称为链接。

8. 目录包含子目录的含义

目录包含指向子目录i-节点的链接。

9. 目录有个父目录的含义:

目录包含..的链接,即指向父目录。

. 文件没有名字只有i-节点号,但是链接可以有名字 ,一个文件可以有多个链接(他们的名字也可以不同,但是他们指向一个文件,对他们的操作就是对源文件的操作)

. Unix系统可以包含多个文件系统,每个文件系统都是一棵独立的树,都有根目录,但是系统可以将他们整合成一棵大树,即一个树的根装载到另一个数的某个节点上。mount

符号链接通过文件名引用文件,可以跨越文件系统,也可以指向目录。相当于windows中快捷方式。

硬链接是将目录链接到树的指针,同时也是将文件名和文件本身链接起来的指针。通过对i-节点号引用文件。

.与目录树相关的命令和系统调用

命令 mkdir

实现 头文件 #include <sys/stat.h> #include <sys/types.h>

函数原型 int res=mkdir (char *path,mode_t mode);

命令 rmdir 删除一个目录,这个目录必须是空的

实现 头文件#include <unistd.h>

函数原型int res=rmdir (const char* path);

命令 rm 减少相应i-节点连接数,若此时节点书减为0,就释放数据块和节点。不能用来删除目录

实现 头文件#include <unistd.h>

函数原型int res=unlink (const char *path);

命令 ln 不能用来生成目录的链接。

实现 头文件#include <unistd.h>

函数原型 int res=link (const char *old,const char *new);

命令 mv 删除原来的目录,复制到新的里面

实现 头文件#include <unistd.h>

函数原型int res=rename (const char* from,const char *to);

原理:复制链接到新的名字/位置再删除原来的链接

if(link("x","z")!=-1)

unlink("x");

命令 cd 对进程有影响,对目录本身没有影响

实现 头文件 #include <unistd.h>

函数原型 int res=chdir (const char *path);

. pwd 命令的实现

Unix文件系统和pwd命令实现详解(unix的文件系统采用)

#include <stdio.h>

#include <sys/types.h>

#include <sys/stat.h>

#include <dirent.h>

#include <string.h>

#include <unistd.h>

ino_t get_inode(char *);//get the inode number

void printpathto(ino_t);

void inum_to_name(ino_t,char *,int);//get the node name by its inode number

int main()

{

printpathto(get_inode("."));

putchar('n');

return 0;

}

void printpathto(ino_t this_inode)

{

ino_t my_inode;

char its_name[BUFSIZ];

if(get_inode("..")!=this_inode)

{

chdir(".."); //up one dir

inum_to_name(this_inode,its_name,BUFSIZ); //get its name

my_inode=get_inode(".");

printpathto(my_inode); //itorater

printf("/%s",its_name);

}

}

void inum_to_name(ino_t inode_to_find,char *namebuf,int buflen)

{

DIR *dir_ptr; //the directory

struct dirent *direntp; //each entry

dir_ptr=opendir(".");

if(dir_ptr==NULL)

{

perror(".");

return;

}

while((direntp=readdir(dir_ptr))!=NULL)

{

if(direntp->d_ino==inode_to_find)

{

strncpy(namebuf,direntp->d_name,buflen);

namebuf[buflen-1]='';

closedir(dir_ptr);

return;

}

}

fprintf(stderr,"error looking for inum %dn",(int)inode_to_find);

return;

}

ino_t get_inode(char *fname)

{

struct stat info;

if(stat(fname,&info)==-1)

{

fprintf(stderr,"Can not stat");

perror(fname);

return 1;

}

return info.st_ino;

}

运行结果:

caoli@caoli-laptop:~/workspace/test$ ./pwd1

/home/caoli/workspace/test

caoli@caoli-laptop:~/workspace/test$

FreeBSD下zfs: failed with error 6错误如何解决? 环境:重编译完内核,安装后重启,显示:zfs:failedwitherror6,然后就是mountroot提示了。这是一种很少见的zfs错误代码,一般2或居多。追踪:看最后一行

Freebsd PF 安装使用详解 FreebsdPF安装使用FreeBSD下的PFFreeBSD下的包过滤工具有IPFW,IPF以及PF,它们各有特点。PF原本是OpenBSD下的包过滤工具,FreeBSD开发人员已经把PF移植到了FreeBSD

FreeBSD如何添加硬盘?FreeBSD添加硬盘的方法 FreeBSD添加硬盘在平时的使用中,由于数据的增多,可能会出现单块磁盘不够用的情况。这时,就需要给FreeBSD再增加一块磁盘,分区,格式化,再将分区

标签: unix的文件系统采用

本文链接地址:https://www.jiuchutong.com/biancheng/350527.html 转载请保留说明!

上一篇:Unix中的dot命令详解(unix du)

下一篇: FreeBSD下zfs: failed with error 6错误如何解决?

  • 企业所得税税负高是什么意思
  • 城建税计税依据扣除增值税期末留抵
  • 个体户一年能开多少普票
  • 年末未分配利润怎么处理
  • 股份支付为什么计入股本溢价
  • 调整多计提所得税的分录
  • 同产品不同单价能相加开票吗
  • 模具发票如何入账
  • 1%是什么税
  • 房地产企业拆迁补偿契税政策
  • 由于生产工艺改进引起建筑物设备陈旧
  • 企业减免6%的税的营业范围有哪些?
  • 劳务发票普票怎么开
  • 上月未抵扣完的进项税本月可以抵扣吗
  • 以前工会是没有公章的吗
  • 发票付款证明怎么写
  • 房地产企业开发资质等级
  • 公司为员工负担个税怎么做账
  • 电子承兑怎么开户
  • 核销单怎么做
  • 超过三年的坏帐损失税前扣除怎样规定?
  • 委托加工应税消费品收回后直接销售
  • 供应商赠送的原材料怎么做分录
  • 应收票据质押怎么看
  • w7系统怎么用
  • 巴蒂斯塔卡里
  • win10蓝牙怎么开ldac
  • 承租人经营租赁会计分录
  • 子公司增发股票母公司为什么会产生利得
  • 用银行存款支付本季度短期借款利息
  • mac osx10.11
  • php轻松入门视频教程
  • php read
  • 实收资本的会计编码
  • 印度活根桥 (© dhritipurna/Shutterstock)
  • 货币资金属于
  • php解压压缩包
  • 劳务公司给包工头打款备注写什么
  • php-xml
  • 预缴所得税会计分录咋做
  • 进项税年末结转分录
  • od输出结构
  • css怎么让文字垂直居中显示
  • 织梦好用吗
  • 帝国cms真的很好用
  • 企业支付给其他单位劳务费时需要代扣代缴个税吗
  • 怎么连接php
  • 股东借款怎么转为利润分配
  • 消防预付款怎么做分录
  • 企业进行股权转让前,必须先销什么户
  • 什么叫金税四期呢?
  • 认缴的出资额
  • 劳务公司开出的劳务票需要申报个税吗
  • 跨月的增值税普通发票能作废吗
  • 增值税专用发票几个点
  • 城镇土地使用税征收标准及计算方法
  • 售后租回交易的表述
  • 内控制度包括哪几方面
  • 外购材料用于建筑工程会计分录
  • 库存商品的成本
  • 测绘费发票图片
  • 空调的折旧年限是多少年的
  • 电脑算固定资产哪一类
  • mysql和mysql数据库的区别
  • 如何更改win8开始菜单
  • windows远程桌面连接怎么用
  • 进程 内核栈
  • shwiconem.exe - shwiconem是什么进程 有什么用
  • win7旗舰版64位系统开机时软件设置自动启动详细图文教程
  • opengl点的绘制
  • linux开机启动进程
  • jquery 鼠标悬浮显示文字
  • javascript高级程序设计第五版 pdf下载
  • jquery操作元素样式
  • 如何用javascript
  • Java如何获得集合里的元素
  • 东莞市税务局稽查局
  • 财税36号文附件3
  • 北京的个人所得税怎么算
  • 徐州市哪些区域有疫情
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设