转载:python 实现操作系统

python文件系统模拟

文章来源:企鹅号 - 老虎太太的咖啡馆

OS课设:python的类ufs的多用户文件系统模拟。

 

结构图

github 地址:

https://github.com/TIGERTAITAI/FileSystem-Simulation

不想用c写的最主要原因是为了强迫自己不要抄代码(c++的文件系统源码网上比较多,用python写的少)。

文件系统模拟ufs格式。

用python的multiprocessing.connection Server 和Listener去处理多用户进程。

inodes和data blocks,以及各自的map。inodes是类数组data blocks是bytes数组。用bytes数组去模拟各种文件读写操作,包括目录文件。

写代码遇到的最大问题就是不知道系统结构怎样写比较好。如何巧妙利用语言的特性同时又要在原理上不破坏文件系统的机制。比如map的设置就是一个对文件系统的模拟,但事实上在python里直接对list操作会更加方便。

另外的一个问题是刚开始写的时候用一些外部函数去处理,然后就写的很乱。比如我要新建一个文件,就需要分配inode和block,然后用一个inode去记录所有分配的blocks,就要牵涉到inode, inodelist, inodeindex, inodemap, block, blocklist, blockindex, blockmap。往函数传参数时有时都不知道自己传的是inode还是inodeindex, inodeindex是list的index还是二维的map的index。然后函数又要调用一些子函数,很乱。各种参数和函数导致维护性很差,不好写。

最后代码经过了一次重构,设计了一些manager类去统一管理,并且规范之间的接口。如结构图所述。就清晰很多。

github里有使用说明。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值