首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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里有使用说明。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180624G0OHJC00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券