ImageVerifierCode 换一换
格式:DOCX , 页数:54 ,大小:387.04KB ,
资源ID:16192679      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-16192679.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(操作系统课程设计文件管理二级文件系统.docx)为本站会员(b****7)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

操作系统课程设计文件管理二级文件系统.docx

1、操作系统课程设计文件管理二级文件系统本文档分别包含linux和windows两套程序一、课程设计的目的 二、课程设计的内容及要求 内容 要求 三、实现原理 四、关键算法实现流程图 流程图 关键算法 五、软件运行环境及限制 六结果输出及分析 七心得体会 八参考文献 一课程设计的目的本课程设计是学习完计算机操作系统课程后,进行的一次全面的综合训练,通过课程设计,让我更好地掌握操作系统的原理及实现方法,加深对操作系统基础理论和重要算法的理解,加强了我的动手能力。二课程设计的内容及要求内容:为LINUX 设计一个简单的二级文件系统。要求做到以下几点:1、可以实现下列几条命令(至少4条)。Login 用

2、户登录Dir 列文件目录Create 创建文件Delete 删除文件Open 打开文件Close 关闭文件Read 读文件Write 写文件2、列目录时要列出文件名、物理地址、保护码和文件长度。3、源文件可以进行读写保护。从课程设计的目的出发,通过设计工作的各个环节,达到以下教学要求:1、鼓励并优先个人独立选题设计,可从下面设计题目中选择,也可以自拟相关题目;如要合作,每组最多两名同学,且设计文档不能相同;2、可以在我们实验课最后布置的实验设计基础上进行完善和改进,但不能相同。3、题目选定后报给班长,班长要注意班级内题目的平衡,根据所选题目进行协调,不要都选一样的题。4、设计完成后报请老师答辩

3、,答辩时不能对自己提供的设计进行讲解的同学,视为抄袭;5、要求写出一份详细的设计报告(A4纸)。6、每位同学在周五将自己的设计报告和电子文档(包括报告和源程序)交给学习委员,并由学习委员统一刻盘后上交。三实现原理 首先,实现Login用户登录,(用户名:admin 密码:admin)必须登录成功才能进入文件系统进行查看,进入后,通过树状展示文件目录(默认文件目录是C:Program Files),右侧显示文件夹图标或者文件图标,选中节点鼠标右击弹出菜单,有新建目录,新建文件,删除文件,打开文件,属性菜单项,并分别实现其功能。四关键算法实现流程图流程图:关键算法:1 新建目录功能的实现priva

4、te class MenuAction2 implements ActionListener public void actionPerformed(ActionEvent arg0) try String Name=JOptionPane.showInputDialog(创建目录名称:); if (!Name.equals() / 得到树状视图的被选择节点路径 TreePath path = tree.getSelectionPath(); / 得到树状视图的被选择节点 MutableTreeNode node = (MutableTreeNode) path .getLastPathCom

5、ponent(); / 得到树状视图的模型类变量 DefaultTreeModel model = (DefaultTreeModel) tree.getModel(); / 新建子节点,标题为新目录名称 MutableTreeNode newNode = new DefaultMutableTreeNode(Name); / 先展开树状视图,触发展开树状视图事件,给当前节点追加下级节点 tree.fireTreeExpanded(path); / 如果当前节点允许存在下级节点,则在树状视图的模型类变量中插入新子节点,位置是第一个,否则显示消息并退出该函数 if (node.getAllows

6、Children() model.insertNodeInto(newNode, node, 0); else JOptionPane.showMessageDialog(null, 不能给文件追加下级目录!); return; / 得到被选择节点对应文件的完整路径信息 String fullPath = ; for (Object obj : path.getPath() String str = obj.toString(); / 处理盘符根目录问题 if (str.endsWith() str = str.substring(0, str.length() - 1); if (fullP

7、ath.equals() fullPath += str; else fullPath += + str; /System.out.println(fullpath=+fullPath); / 生成被选择节点对应的文件类变量 File parentDir = new File(fullPath); / 如果是目录,则新建相应的子目录 if (parentDir.isDirectory() File currentFile = new File(fullPath + + Name); currentFile.mkdir(); else JOptionPane.showMessageDialog(

8、null, 文件名不能为空!); catch (HeadlessException e) / TODO Auto-generated catch block e.printStackTrace(); 2.新建文件功能的实现 private class MenuAction5 implements ActionListener public void actionPerformed(ActionEvent e) TreePath tp = tree.getSelectionPath();/ 得到被选择节点对应文件的完整路径信息 String fullPath = ; for (Object ob

9、j : tp.getPath() String str = obj.toString(); / 处理盘符根目录问题 if (str.endsWith() str = str.substring(0, str.length() - 1); if (fullPath.equals() fullPath += str; else fullPath += + str; String FileName = JOptionPane.showInputDialog(创建文件名称:); if (!FileName.equals(null) File f = new File(fullPath + + File

10、Name); try f.createNewFile(); catch (IOException e1) / TODO Auto-generated catch block e1.printStackTrace(); else JOptionPane.showMessageDialog(null, 文件名不能为空!); 3.删除功能的实现 / 内部类,响应快捷菜单的单击操作 private class MenuAction implements ActionListener public void actionPerformed(ActionEvent e) / 得到树状视图的被选择节点路径

11、TreePath tp = tree.getSelectionPath(); / 得到树状视图的被选择节点 DefaultMutableTreeNode node = (DefaultMutableTreeNode) tp .getLastPathComponent(); / 从树状视图删除当前节点 DefaultTreeModel dtm = (DefaultTreeModel) tree.getModel(); dtm.removeNodeFromParent(node); / 得到被选择节点对应文件的完整路径信息 String fullPath = ; for (Object obj :

12、 tp.getPath() String str = obj.toString(); / 处理盘符根目录问题 if (str.endsWith() str = str.substring(0, str.length() - 1); if (fullPath.equals() fullPath += str; else fullPath += + str; / 如果是文件,直接删除,如果是目录则调用deleteDir函数删除目录 File currentFile = new File(fullPath); if (currentFile.isFile() currentFile.delete()

13、; else deleteDir(currentFile); ; / 通过递归调用,可以删除目录的函数 public static boolean deleteDir(File dir) / 判断是否为目录,如果是,则递归调用自己,如果不是,直接删除文件 if (dir.isDirectory() String subDir = dir.list(); for (String s : subDir) deleteDir(new File(dir, s); return dir.delete(); 4.打开文件的功能实现即是Open_File这个类。5.属性的功能实现取得路径名:TreePath

14、 tp = tree.getSelectionPath();/ 得到被选择节点对应文件的完整路径信息 String fullPath = ; for (Object obj : tp.getPath() String str = obj.toString(); / 处理盘符根目录问题 if (str.endsWith() str = str.substring(0, str.length() - 1); if (fullPath.equals() fullPath += str; else fullPath += + str; 然后传入new Proper(fullPath);属性详细实现即是

15、Proper类。五软件运行环境及限制运行环境:JDK 1.6使用语言:Java编程工具:JBuilder2007错误提示框进入系统后主界面:菜单选项:新建目录“小小”新建文件“小小”删除“小小”目录及文件删除成功打开文件查看文件属性七心得体会操作系统课程设计,自己通过查找资料、复习课本、编程调试,写实验报告等环节,进一步掌握了以前学到的知识,并且还对操作系统应用有了更深入的认识与掌握。比如对树的展示有了很好的学习,对二级文件系统也有了很好的了解,如何解决实现里面功能的各种问题。 通过实践的学习,我认到学好计算机要重视实践操作,不仅仅是学习java语言,还是其它的语言,以及其它的计算机方面的知识

16、都要重在实践,所以后在学习过程中,我会更加注视实践操作,使自己便好地学好计算机。八参考文献1朱福喜,尹为民等编著.Java语言与面向对象程序设计.武汉:武汉大学出版社,2002.12 2陆昌辉,Java程序设计实用案例教程.北京:电子工业出版社,2008.53丁振凡,黎章等编著.Java语言实用教程.北京:北京邮电大学出版社,2005.84何桥,李肃义等编著.Java程序设计简明教程.北京:中国水利水电出版社,2004.9 文件管理系统模拟1.实验目的通过一个简单多用户文件系统的设计,加深理解文件系统的内部功能及内部实现2.实验内容为Linux系统设计一个简单的二级文件系统。要求做到以下几点:

17、(1)可以实现下列几条命令(至少4条)login 用户登录dir 列文件目录create 创建文件delete 删除文件open 打开文件close 关闭文件read 读文件write 写文件(2)列目录时要列出文件名、物理地址、保护码和文件长度;(3)源文件可以进行读写保护。3.实验提示(1)首先应确定文件系统的数据结构:主目录、子目录及活动文件等。主目录和子目录都以文件的形式存放于磁盘,这样便于查找和修改。(2)用户创建的文件,可以编号存储于磁盘上。入file0,file1,file2并以编号作为物理地址,在目录中进行登记。4.源代码#include #include #include #

18、define MEM_D_SIZE 1024*1024 /总磁盘空间为1M#define DISKSIZE 1024 /磁盘块的大小1K#define DISK_NUM 1024 /磁盘块数目1K#define FATSIZE DISK_NUM*sizeof(struct fatitem) /FAT表大小#define ROOT_DISK_NO FATSIZE/DISKSIZE+1 /根目录起始盘块号#define ROOT_DISK_SIZE sizeof(struct direct) /根目录大小#define DIR_MAXSIZE 1024 /路径最大长度为1KB#define MSD

19、 5 /最大子目录数5#define MOFN 5 /最大文件深度为5#define MAX_WRITE 1024*128 /最大写入文字长度128KB struct fatitem /* size 8*/ int item; /*存放文件下一个磁盘的指针*/ char em_disk; /*磁盘块是否空闲标志位 0 空闲*/ ; struct direct /*-文件控制快信息-*/ struct FCB char name9; /*文件/目录名 8位*/ char property; /*属性 1位目录 0位普通文件*/ int size; /*文件/目录字节数、盘块数)*/ int fi

20、rstdisk; /*文件/目录 起始盘块号*/ int next; /*子目录起始盘块号*/ int sign; /*1是根目录 0不是根目录*/ directitemMSD+2; ; struct opentable struct openttableitem char name9; /*文件名*/ int firstdisk; /*起始盘块号*/ int size; /*文件的大小*/ openitemMOFN; int cur_size; /*当前打文件的数目*/ ; struct fatitem *fat; /*FAT表*/ struct direct *root; /*根目录*/

21、struct direct *cur_dir; /*当前目录*/ struct opentable u_opentable; /*文件打开表*/ int fd=-1; /*文件打开表的序号*/ char *bufferdir; /*记录当前路径的名称*/ char *fdisk; /*虚拟磁盘起始地址*/ void initfile(); void format(); void enter(); void halt(); int create(char *name); int open(char *name); int close(char *name); int write(int fd,c

22、har *buf,int len); int read(int fd,char *buf); int del(char *name); int mkdir(char *name); int rmdir(char *name); void dir(); int cd(char *name); void print(); void show(); void initfile() fdisk = (char *)malloc(MEM_D_SIZE*sizeof(char); /*申请 1M空间*/ format(); void format() int i; FILE *fp; fat = (str

23、uct fatitem *)(fdisk+DISKSIZE); /*计算FAT表地址,引导区向后偏移 1k)*/ /*-初始化FAT表-*/ fat0.item=-1; /*引导块*/ fat0.em_disk=1; for(i=1;iROOT_DISK_NO-1;i+) /*存放 FAT表的磁盘块号*/ fati.item=i+1; fati.em_disk=1; fatROOT_DISK_NO.item=-1; /*存放根目录的磁盘块号*/ fatROOT_DISK_NO.em_disk=1; for(i=ROOT_DISK_NO+1;idirectitem0.sign = 1; root

24、-directitem0.firstdisk = ROOT_DISK_NO; strcpy(root-directitem0.name,.); root-directitem0.next = root-directitem0.firstdisk; root-directitem0.property = 1; root-directitem0.size = ROOT_DISK_SIZE; /*-指向上一级目录的目录项-*/ root-directitem1.sign = 1; root-directitem1.firstdisk = ROOT_DISK_NO; strcpy(root-direc

25、titem1.name,.); root-directitem1.next = root-directitem0.firstdisk; root-directitem1.property = 1; root-directitem1.size = ROOT_DISK_SIZE; if(fp = fopen(disk.dat,wb)=NULL) printf(Error:n Cannot open file n); return; for(i=2;idirectitemi.sign = 0; root-directitemi.firstdisk = -1; strcpy(root-directit

26、emi.name,); root-directitemi.next = -1; root-directitemi.property = 0; root-directitemi.size = 0; if(fp = fopen(disk.dat,wb)=NULL) printf(Error:n Cannot open file n); return; if(fwrite(fdisk,MEM_D_SIZE,1,fp)!=1) /*把虚拟磁盘空间保存到磁盘文件中*/ printf(Error:n File write error! n); fclose(fp); void enter() FILE *fp; int i; fdisk = (char *)malloc(MEM_D_SIZE*sizeof(char); /*申

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2