版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 課程設(shè)計(jì)</b></p><p> 題 目:文件系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn) </p><p><b> 學(xué)生姓名: </b></p><p> 學(xué) 院:信息工程學(xué)院</p><p> 系 別:計(jì)算機(jī)系 </p><p> 專 業(yè)
2、:計(jì)算機(jī)科學(xué)與技術(shù) </p><p><b> 班 級(jí): </b></p><p><b> 指導(dǎo)教師: </b></p><p> 2011年12月30日</p><p><b> 課程設(shè)計(jì)任務(wù)書</b></p><p><b>
3、 目錄</b></p><p> 第一章設(shè)計(jì)內(nèi)容1</p><p> 1.1 設(shè)計(jì)目的1</p><p> 1.2 設(shè)計(jì)要求1</p><p> 1.3 程序設(shè)計(jì)思想1</p><p> 第二章 數(shù)據(jù)結(jié)構(gòu)、算法和算法流程圖2</p><p> 2.1 數(shù)據(jù)結(jié)
4、構(gòu)2</p><p> 2.2 程序功能圖3</p><p> 2.3 程序流程圖3</p><p> 第三章 程序運(yùn)行結(jié)果及分析7</p><p> 3.1 程序運(yùn)行結(jié)果7</p><p> 3.2 程序分析8</p><p> 第四章 心得體會(huì)9</p>
5、<p><b> 參考文獻(xiàn)10</b></p><p> 附錄 程序清單11</p><p><b> 設(shè)計(jì)內(nèi)容</b></p><p><b> 1.1 設(shè)計(jì)目的</b></p><p> 通過設(shè)計(jì)一個(gè)小型文件系統(tǒng),進(jìn)一步掌握文件管理的方法和技術(shù),
6、使學(xué)生初步具有研究、設(shè)計(jì)、編制和調(diào)試操作系統(tǒng)模塊的能力。</p><p><b> 1.2 設(shè)計(jì)要求</b></p><p><b> (1) 問題描述</b></p><p> 在任一OS下,建立一個(gè)大文件,把它假想成一張盤,在其中實(shí)現(xiàn)一個(gè)簡(jiǎn)單的小型文件系統(tǒng)。</p><p><b&g
7、t; (2) 基本要求</b></p><p> 該文件系統(tǒng)沒有子目錄機(jī)制,文件連續(xù)分配,不考慮換“盤”和分區(qū)。做一個(gè)簡(jiǎn)單的操作界面,提供五條簡(jiǎn)單的命令:dir、mkfile、type、copy、delfile,分別用于顯示文件目錄、建立文件、顯示文件內(nèi)容、復(fù)制和刪除一個(gè)文件。</p><p> 1.3 程序設(shè)計(jì)思想</p><p> 閱讀操作系
8、統(tǒng)方面的書籍,了解操作系統(tǒng)的文件系統(tǒng)原理。結(jié)合分析課程設(shè)計(jì)要求,確定實(shí)體以及它們之間的關(guān)系。實(shí)體關(guān)系有三張表(磁盤空間分配表、文件表、打開文件表)、一個(gè)模擬磁盤的數(shù)組、命令服務(wù)和用戶構(gòu)成。用戶負(fù)責(zé)輸入命令。命令服務(wù)實(shí)現(xiàn)命令的解釋、命令檢查、命令幫助以及調(diào)用相關(guān)模塊執(zhí)行相應(yīng)的命令功能。</p><p> 建立一個(gè)系統(tǒng)文件(模擬盤),并對(duì)此進(jìn)行盤塊的劃分,第一個(gè)盤塊存放文件目錄,第二盤塊存放盤塊位示圖,自第三個(gè)盤塊
9、開始存放各具體文件的內(nèi)容,文件目錄存放文件的名字,文件的擴(kuò)展名,開始盤塊號(hào),所占用的盤塊數(shù)目,文件的大??;盤塊位示圖用來標(biāo)記盤塊是否被占用。</p><p> 構(gòu)造這些實(shí)體的關(guān)系圖,數(shù)據(jù)流圖、程序流程圖來進(jìn)行具體的設(shè)計(jì)。</p><p> 第二章 數(shù)據(jù)結(jié)構(gòu)、算法和算法流程圖</p><p><b> 2.1 數(shù)據(jù)結(jié)構(gòu)</b></p&
10、gt;<p> 數(shù)據(jù)結(jié)構(gòu)說明:本程序所運(yùn)用的主要有兩個(gè)數(shù)據(jù)結(jié)構(gòu),分別如下:</p><p><b> 文件目錄結(jié)構(gòu):</b></p><p> struct filename { //文件目錄項(xiàng)結(jié)構(gòu)體 </p><p> char name[9];
11、 //文件名</p><p> char ext[4]; //擴(kuò)展名</p><p> int i; //文件所占用磁盤塊的第一個(gè)磁盤塊號(hào)</p><p> int Amount; //文件所占用磁盤塊的塊數(shù)</p><p>
12、; long int size; //文件大小</p><p><b> };</b></p><p><b> 盤塊結(jié)構(gòu):</b></p><p> struct empty { //盤塊結(jié)構(gòu)體</p><p>
13、 int map[100]; //盤塊位示圖</p><p> int filenum; //文件數(shù)量</p><p><b> }; </b></p><p><b> 2.2 程序功能圖</b></p><p> 文件系統(tǒng)提供
14、的文件操作有建立文件(mkfile)、復(fù)制文件(copy)、顯示文件所有內(nèi)容(type)、刪除文件(delfile)??梢酝ㄟ^鍵盤輸入命令來模擬文件的操作。</p><p><b> 2.3 程序流程圖</b></p><p> ?。?)主程序流程圖:</p><p> ?。?)初始化模塊流程圖:</p><p>
15、(3)寫入磁盤流程圖:</p><p> (4)顯示目錄流程圖:</p><p> (5)顯示文件流程圖:</p><p> ?。?)刪除文件流程圖:</p><p> (7)復(fù)制文件流程圖:</p><p> ?。?)創(chuàng)建文件流程圖:</p><p> 第三章 程序運(yùn)行結(jié)果及分析<
16、;/p><p> 3.1 程序運(yùn)行結(jié)果</p><p><b> ?。?)程序主界面</b></p><p> (2)創(chuàng)建一個(gè)文件,輸入“3”顯示“輸入文件內(nèi)容,按@ 鍵保存且退出!”</p><p> ?。?)往文件里寫內(nèi)容:Hello World!顯示文件長(zhǎng)度,并要求給文件命名,命名后保存返回主界面</p>
17、;<p> (4)讀取剛才寫入的文件,結(jié)果正確</p><p> ?。?)刪除剛寫入的文件,測(cè)試成功</p><p><b> 3.2 程序分析</b></p><p> 本程序使用一個(gè)Windows下的文件來模擬一個(gè)磁盤,向磁盤中裝入文件并進(jìn)行相關(guān)操作。采用了以空間換時(shí)間的算法,文件的大小在系統(tǒng)中是固定的,雖然會(huì)浪費(fèi)一些空
18、間,但文件的存取速率會(huì)加快。</p><p><b> 第四章 心得體會(huì)</b></p><p> 操作系統(tǒng)課程設(shè)計(jì)是本課程重要的實(shí)踐教學(xué)環(huán)節(jié)。課程設(shè)計(jì)的目的,一方面使學(xué)生更透徹地理解操作系統(tǒng)的基本概念和原理,使之由抽象到具體;另一方面,通過課程設(shè)計(jì)加強(qiáng)學(xué)生的實(shí)驗(yàn)手段與實(shí)踐技能,培養(yǎng)學(xué)生獨(dú)立分析問題、解決問題、應(yīng)用知識(shí)的能力和創(chuàng)新精神。與本課程的實(shí)驗(yàn)教學(xué)相比,課程
19、設(shè)計(jì)獨(dú)立設(shè)課,具有更多的學(xué)時(shí),給學(xué)生更多自行設(shè)計(jì)、自主實(shí)驗(yàn)的機(jī)會(huì),充分放手讓學(xué)生真正培養(yǎng)學(xué)生的實(shí)踐動(dòng)手能力,全面提高學(xué)生的綜合素質(zhì)。</p><p> 在設(shè)計(jì)的過程中遇到問題,可以說得是困難重重,難免會(huì)遇到過各種各樣的問題,同時(shí)在設(shè)計(jì)的過程中發(fā)現(xiàn)了自己的不足之處,對(duì)以前所學(xué)過的知識(shí)理解得不夠深刻,掌握得不夠牢固,不過設(shè)計(jì)終于順利完成了,在設(shè)計(jì)中遇到了很多編程問題,最后在老師的辛勤指導(dǎo)下,終于游逆而解。同時(shí),在老
20、師的身上我學(xué)得到很多實(shí)用的知識(shí),再次我表示感謝!同時(shí),對(duì)給過我們幫助的所有同學(xué)和各位指導(dǎo)老師再次表示忠心的感謝!</p><p> 在設(shè)計(jì)過程中,查詢了不少相關(guān)資料,不斷的發(fā)現(xiàn)問題、提出問題、解決問題。在對(duì)自己所編寫的源程序段的糾錯(cuò)的過程中,使我更好的理解了操作系統(tǒng)中文件系統(tǒng)的理論知識(shí),同時(shí)在編程時(shí)用到了模塊化的設(shè)計(jì)思想,這種編程方法可以使我們的編程變的更簡(jiǎn)單,可以使我們的查錯(cuò)與糾錯(cuò)變的更方便。總的來說通過這次
21、的設(shè)計(jì)的學(xué)習(xí)使我學(xué)到了很多在平時(shí)的學(xué)習(xí)中學(xué)不到的很多東西,通過這次課程設(shè)計(jì),使我對(duì)操作系統(tǒng)和編程產(chǎn)生興趣,我想我會(huì)在這條路上繼續(xù)前進(jìn)下去。我相信,只要不斷的嚴(yán)格要求自己,注意培養(yǎng)自己的思維能力,就一定會(huì)有更大更輝煌的發(fā)展和提高。</p><p><b> 參考文獻(xiàn)</b></p><p><b> 1. 教材</b></p>&
22、lt;p> [1] 張堯?qū)W主編.計(jì)算機(jī)操作系統(tǒng)教程(第三版).北京:清華大學(xué)出版社,2006</p><p><b> 2. 主要參考書 </b></p><p> [1] 張堯?qū)W編.計(jì)算機(jī)操作系統(tǒng)教程(第三版)習(xí)題解答與實(shí)驗(yàn)指導(dǎo).北京:清華大學(xué)出版社,2006</p><p> [2] 湯子瀛主編.計(jì)算機(jī)操作系統(tǒng)(第三版).西安
23、:西安電子科技大學(xué)出版社,2001 </p><p> [3] 張坤等編.操作系統(tǒng)實(shí)驗(yàn)教程.北京:清華大學(xué)出版社,2008</p><p> [4] 張麗芬等編.操作系統(tǒng)實(shí)驗(yàn)教程.北京:清華大學(xué)出版社,2006</p><p> [5] Andrew S.Tanenbaum. Modern Operating Systems, Second Edition.E
24、nglewood Cliffs,N.J,Prentice Hall, 2001</p><p> [6] 屠祁等編.操作系統(tǒng)基礎(chǔ)(第三版).北京:清華大學(xué)出版社,2000</p><p> [7] 馮耀霖等編.操作系統(tǒng).西安:西安電子科技大學(xué)出版社,2001</p><p> [8] 左萬(wàn)歷.計(jì)算機(jī)操作系統(tǒng)教程(第二版).北京:高等教育出版社,2004<
25、/p><p><b> 附錄 程序清單</b></p><p> #include "iostream.h"</p><p> #include "string"</p><p> #include "stdio.h"</p><p>
26、; extern "C" void exit(int);</p><p> struct filename //文件目錄項(xiàng)結(jié)構(gòu)體 </p><p><b> {</b></p><p> char name[12];
27、//文件名</p><p> char ext[8]; //擴(kuò)展名//擴(kuò)展名較小設(shè)為10</p><p> int i; //文件所占用磁盤塊的第一個(gè)磁盤塊號(hào)</p><p> int Amount; //文件所占用磁盤塊的塊數(shù)</p>
28、;<p> long int size; //文件大小</p><p> }file[20];</p><p><b> int num;</b></p><p> struct empty //盤塊結(jié)構(gòu)體</p><p>
29、; { int map[20]; //盤塊位示圖</p><p> int filenum; //文件數(shù)量</p><p> }emptytable; </p><p><b> //模塊說明:</b></p><p> void S
30、ystemInit() //模擬磁盤文件初始化函數(shù)</p><p><b> { </b></p><p> for(int i=2;i<19;i++) { //初始化存放位示圖的盤塊</p><p> emptytable.map[i]=0;</p&
31、gt;<p><b> }</b></p><p> emptytable.map[0]=1;</p><p> emptytable.map[1]=1;</p><p> emptytable.filenum=0;</p><p><b> FILE *fp;</b>&l
32、t;/p><p> if((fp=fopen("filesys","wb+"))==NULL) //wb+:為讀寫建立一個(gè)"新"文件;打開系統(tǒng)文件將文件目錄盤塊和用“w”打開的文件只能向該文件寫入。若打開的文件不存在,則以指定的文件名建立該文件,若打開的文件已經(jīng)存在,則將該文件刪去,重建一個(gè)新文件。+: 讀和寫</p><p>
33、 { //位示圖盤塊寫入系統(tǒng)文件</p><p> printf("can not open file \n");</p><p><b> exit(0);</b></p><p><b> }</b></p>&l
34、t;p> fseek(fp,512L,0); // int fseek(FILE *stream, long offset, int fromwhere); 函數(shù)設(shè)置文件指針stream的位置。如果執(zhí)行成功,stream將指向以fromwhere(偏移起始位置:文件頭0,當(dāng)前位置1,文件尾2)為基準(zhǔn),偏移offset(指針偏移量)個(gè)字節(jié)的位置。如果執(zhí)行失敗(offset超過文件自身大小),則不改變stream指向
35、的位置。成功,返回0,否則返回其他值。</p><p> fwrite(&emptytable,sizeof(struct empty),1,fp); //把結(jié)構(gòu)體emptyable中的內(nèi)容寫入到fp中,數(shù)據(jù)項(xiàng)的大小為struct empty,數(shù)據(jù)項(xiàng)的個(gè)數(shù)為1</p><p> fclose(fp);</p><p> printf("
36、!!!初始化系統(tǒng)成功!!!");</p><p><b> }</b></p><p> void WriteFile() //將目錄以及空閑盤塊表寫入磁盤</p><p> { </p><p><b> FIL
37、E *fp;</b></p><p> if((fp=fopen("filesys","rb+"))==NULL)</p><p><b> {</b></p><p> printf("can not open file \n");</p><p
38、><b> exit(0);</b></p><p><b> }</b></p><p> rewind(fp); //將文件內(nèi)部的位置指針重新指向一個(gè)流(數(shù)據(jù)流/文件)的開頭</p><p> for(int i=0;i<num;i++)</p><p><b&
39、gt; {</b></p><p> fwrite(&file[i],sizeof(struct filename),1,fp); //文件目錄</p><p><b> }</b></p><p> fseek(fp,512L,0);</p><p> fwrite(&em
40、ptytable,sizeof(struct empty),1,fp); //位示圖</p><p> fclose(fp);</p><p><b> }</b></p><p> void dir() //顯示文件目錄</p>
41、<p> { int i,j;</p><p><b> FILE *fp;</b></p><p> if((fp=fopen("filesys","rb"))==NULL)</p><p> {printf("can not open file \n");
42、</p><p><b> exit(0);</b></p><p><b> } </b></p><p> fseek(fp,512L,0); //空閑盤塊表的定位</p><p> fread(&emptyta
43、ble,sizeof(struct empty),1,fp);</p><p> rewind(fp); //文件目錄表的定位</p><p> num=emptytable.filenum;</p><p> for(i=0;i<num;i++)</p><
44、;p> fread(&file[i],sizeof(struct filename),1,fp);</p><p> if (num!=0)</p><p> { printf("系統(tǒng)所有文件:\n");</p><p> for(i=0,j=1;i<num;i++,j++)</p><p>&
45、lt;b> { </b></p><p> printf("%s.%s",file[i].name,file[i].ext);</p><p><b> if(j==5)</b></p><p> { printf("\n");</p><p><
46、b> j=1;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> printf("\n文件數(shù)量為 %d ",num);</p>
47、<p> fclose(fp);</p><p><b> }</b></p><p> void type() //顯示文件內(nèi)容</p><p><b> { </b></p><p><b>
48、; FILE *fp;</b></p><p><b> int i,j;</b></p><p> if((fp=fopen("filesys","rb"))==NULL)</p><p> {printf("can not open file \n");<
49、;/p><p><b> exit(0);</b></p><p><b> }</b></p><p> fseek(fp,512L,0);</p><p> fread(&emptytable,sizeof(struct empty),1,fp);</p><p&
50、gt; rewind(fp);</p><p> num=emptytable.filenum;</p><p> for(i=0,j=0;i<num;i++,j++)</p><p> { fread(&file[i],sizeof(struct filename),1,fp);</p><p> print
51、f("%s.%s",file[i].name,file[i].ext); </p><p> if(j==5) printf("\n");</p><p><b> }</b></p><p> printf("\n");</p><p>
52、 char name[12],ext1[8];</p><p> printf("請(qǐng)輸入所要查詢的文件名:\n");</p><p> gets(name); //scanf("%s",name);//getchar(); </p><p> printf("請(qǐng)輸入擴(kuò)展名:");<
53、;/p><p> gets(ext1); //scanf("%s",ext1);getchar();</p><p> if(*(name+0)=='\0')</p><p><b> {</b></p><p> printf("文件名不能為空 ! \n&qu
54、ot;);</p><p><b> return;</b></p><p><b> }</b></p><p> if(*ext1=='\0') </p><p> strcpy(ext1,"txt");</p><p>
55、 int sign=0;</p><p> for(i=0;i<num;i++)</p><p> if((strcmp(file[i].name,name)==0) && (strcmp(file[i].ext,ext1)==0))</p><p> { printf("---所找文件為第%d個(gè)文件----\n&qu
56、ot;,i+1); </p><p><b> sign=1;</b></p><p><b> break;</b></p><p><b> }</b></p><p> if(sign==0)</p><p> { printf(&q
57、uot;無(wú)此文件\n");</p><p><b> return;</b></p><p><b> }</b></p><p><b> //顯示文件</b></p><p> int b,m,n ;</p><p> b=fil
58、e[i].i;</p><p> n=file[i].size;</p><p> printf("---該文件位于第%d塊\n",b+1); </p><p> printf("---從文件讀出的文件長(zhǎng)度為:%d---\n",n);</p><p> /
59、/fseek(fp,b*512L,0);</p><p><b> char cc;</b></p><p> printf("---文件內(nèi)容為:---\n");</p><p> printf(""); </p><p> for( m=0,j=1; m&l
60、t;n; m++,j++) </p><p><b> { </b></p><p> fseek(fp,b*512L+m,0);</p><p> //fread(&cc,sizeof(char),1,fp); </p><p> cc=fgetc(fp);
61、 </p><p> printf("%c",cc);</p><p> if(j%40==0)printf("\n");</p><p><b> }</b></p><p> printf("\n"); </p><p&
62、gt; fclose(fp);</p><p><b> }</b></p><p> void delfile() //刪除一個(gè)文件</p><p><b> { </b></p><p><b>
63、; FILE *fp;</b></p><p><b> int i;</b></p><p> if((fp=fopen("filesys","r"))==NULL)</p><p><b> {</b></p><p> printf
64、("can not open file \n");</p><p><b> exit(0);</b></p><p><b> }</b></p><p> fseek(fp,512L,0);</p><p> fread(&emptytable,sizeof(
65、struct empty),1,fp);</p><p> rewind(fp);</p><p> num=emptytable.filenum;</p><p> for(i=0;i<num;i++)</p><p> fread(&file[i],sizeof(struct filename),1,fp);<
66、/p><p> char name[12],ext1[8];</p><p> printf("請(qǐng)輸入文件名:\n");</p><p> gets(name);</p><p> //scanf("%s",name);getchar();</p><p> printf(
67、"請(qǐng)輸入擴(kuò)展名:\n");</p><p> gets(ext1);</p><p> //scanf("%s",ext1);getchar();</p><p> if(*name=='\0'){</p><p> printf("文件名不能為空 ! \n&quo
68、t;); </p><p><b> return;</b></p><p><b> }</b></p><p> if(*ext1=='\0') strcpy(ext1,"txt");</p><p> char judge;</p>
69、<p> printf("是否刪除文件%s.%s [y/n]",name,ext1);</p><p> scanf("%c",&judge); getchar();</p><p> if((judge=='y')||(judge=='Y'))</p><p>
70、 printf("準(zhǔn)備刪除文件%s.%s !\n",name,ext1);</p><p> else if((judge=='n')||(judge=='N')) return;</p><p><b> else</b></p><p><b> {</b>&
71、lt;/p><p> printf("系統(tǒng)默認(rèn)放棄!\n");</p><p><b> return;</b></p><p><b> }</b></p><p> int sign=0;</p><p> for(i=0;i<num;i+
72、+){</p><p> if((strcmp(file[i].name,name)==0)&&(strcmp(file[i].ext,ext1)==0))</p><p><b> {</b></p><p><b> sign=1; </b></p><p><b&
73、gt; break;</b></p><p><b> }</b></p><p><b> }</b></p><p> if(sign==0)</p><p> { printf("文件名錯(cuò)\n"); </p><p>&
74、lt;b> return; </b></p><p><b> }</b></p><p><b> //回收空間</b></p><p> int b=file[i].i;</p><p> int Amount=file[i].Amount;</p>
75、<p><b> int j;</b></p><p> for(j=0;j<Amount;j++)</p><p> emptytable.map[b++]=0;</p><p> for( j=i;j<num-1;j++)</p><p><b> { </b>
76、</p><p> strcpy(file[j].name,file[j+1].name);</p><p> strcpy(file[j].ext,file[j+1].ext);</p><p> file[j].i=file[j+1].i;</p><p> file[j].size=file[j+1].size;</p&g
77、t;<p> file[j].Amount=file[j+1].Amount;</p><p><b> }</b></p><p> emptytable.filenum=emptytable.filenum-1;</p><p> num=emptytable.filenum;</p><p>
78、 WriteFile();</p><p> printf("刪除成功!\n");</p><p> fclose(fp);</p><p><b> }</b></p><p> void copy() //復(fù)制
79、一個(gè)文件</p><p><b> { </b></p><p><b> FILE *fq;</b></p><p> int i,j,sign;</p><p> if((fq=fopen("filesys","rb+"))==NULL){&l
80、t;/p><p> printf("can not open file \n");</p><p><b> exit(0);</b></p><p><b> }</b></p><p> fseek(fq,512L,0);</p><p> fr
81、ead(&emptytable,sizeof(struct empty),1,fq);</p><p> rewind(fq);</p><p> num=emptytable.filenum;</p><p> for(i=0;i<num;i++){</p><p> fread(&file[i],sizeof
82、(struct filename),1,fq);</p><p><b> }//for</b></p><p> char SourceName[12],DestName[12],ext1[8],ext2[8];</p><p> printf("請(qǐng)輸入源文件名:");</p><p> g
83、ets(SourceName); //scanf("%s",SourceName);getchar();</p><p> printf("請(qǐng)輸入源文件擴(kuò)展名:");</p><p> gets(ext1); //scanf("%s",ext1
84、);getchar();</p><p> printf("請(qǐng)輸入目標(biāo)文件名:");</p><p> gets(DestName); //scanf("%s",DestName);getchar();</p><p> printf("請(qǐng)輸入目標(biāo)擴(kuò)展文件名")
85、;</p><p> gets(ext2); getchar(); //scanf("%s",ext2);getchar();</p><p> if(*ext2=='\0') strcpy(ext2,"txt");</p><p> if((*SourceName)
86、=='\0' || (*DestName)=='\0'){</p><p> printf("錯(cuò)誤! 文件名不能為空!\n");</p><p><b> return;</b></p><p><b> }</b></p><p> if
87、(strcmp(SourceName,DestName)==0){</p><p> printf("錯(cuò)誤! 兩個(gè)文件名不能相同!\n");</p><p><b> return;</b></p><p><b> }</b></p><p><b> sig
88、n=0;</b></p><p> for(i=0;i<num;i++){</p><p> if(strcmp(SourceName,file[i].name)==0)</p><p> { sign=1;</p><p> strcpy(file[num].name,DestName);</p>
89、<p> strcpy(file[num].ext,ext2);</p><p> //file[num].i=file[i].i;</p><p> file[num].size=file[i].size;</p><p> file[num].Amount=file[i].Amount;</p><p> break;
90、 </p><p><b> }</b></p><p><b> }//for </b></p><p> if(sign==0)</p><p><b> { </b></p>
91、<p> printf("不存在源文件\n");</p><p><b> return;</b></p><p><b> }</b></p><p> if (i<num)</p><p> printf("輸入的文件名與第%d個(gè)源文件相
92、等(i從0開始)\n",i); </p><p><b> //空間分配</b></p><p><b> sign=0;</b></p><p> for(int m=2 ; m<=19-file[num].Amount ; m++) //********************</p
93、><p><b> {</b></p><p> if(emptytable.map[m]==0)</p><p><b> {</b></p><p> for( j=file[i].Amount; j>0; j--){ //尋找一連續(xù)的空閑盤塊</p>
94、<p> if(emptytable.map[m+j-1]==1)</p><p><b> {</b></p><p><b> sign=1;</b></p><p><b> break;</b></p><p><b> }//if<
95、;/b></p><p><b> }//for</b></p><p> if(sign==0) break;</p><p><b> m+=j-1;</b></p><p><b> sign=0;</b></p><p>&l
96、t;b> }</b></p><p><b> }// for</b></p><p> if (m <= 19-file[num].Amount){</p><p> for(j=0;j < file[num].Amount;j++)emptytable.map[m+j]=1;</p>&
97、lt;p> file[num].i=m;</p><p><b> }</b></p><p><b> else</b></p><p> printf("沒有足夠的連續(xù)的盤塊數(shù)");</p><p><b> //寫數(shù)據(jù)</b></
98、p><p> FILE *fq1;</p><p> rewind(fq);</p><p><b> fq1=fq;</b></p><p> fseek(fq,(file[i].i) * 512L,0); </p><p> printf("\n---源文件的起始盤塊號(hào):%d&
99、quot;,file[i].i); </p><p> //rewind(fp1);</p><p> fseek(fq1,(file[num].i) * 512L,0);</p><p> printf("\n---復(fù)制文件的起始盤塊號(hào):%d",file[num].i); </p>&
100、lt;p><b> char cc;</b></p><p> printf("\n---源文件內(nèi)容為:---\n");</p><p> for(int k=0 ; k<file[i].size;k++)</p><p><b> { </b></p><p&
101、gt; fseek(fq,(file[i].i) * 512L+k,0); </p><p> fread(&cc,sizeof(char),1,fq); </p><p> printf("%c",cc);</p><p> fseek(fq1,(file[num].i) * 512L+k,0);
102、 </p><p> fwrite(&cc,sizeof(char),1,fq1);</p><p><b> }</b></p><p> printf("\n"); </p><p> num=num+1;</p><p> emptytable.fil
103、enum=num;</p><p> WriteFile(); //寫目錄及位示圖</p><p> fclose(fq);</p><p> fclose(fq1);</p><p><b> }</b></p><p> v
104、oid mkfile() //建立一個(gè)文件 </p><p> {FILE *fp;</p><p> if((fp=fopen("filesys","r+"))==NULL){</p><p> printf("can no
105、t open file\npleace Initialization at first\n");</p><p><b> exit(0);</b></p><p><b> }</b></p><p> struct strNode //數(shù)據(jù)塊</p><p> {ch
106、ar word[64];</p><p> struct strNode *next;</p><p> }*head,*p,*q;</p><p> char name[9],ext1[4];</p><p> int i=0,j=0;</p><p> head=p=q=new struct strNod
107、e; //申請(qǐng)結(jié)構(gòu)體內(nèi)存空間</p><p><b> char ch;</b></p><p> printf("請(qǐng)輸入文件內(nèi)容,按 @ 鍵保存且退出!\n");</p><p><b> do{</b></p><p> for(i=0;i<64;i++)<
108、;/p><p><b> {</b></p><p> //ch=getchar();</p><p> scanf("%c",&ch);</p><p> p->word[i]=ch;</p><p> if(ch=='@')break;&
109、lt;/p><p><b> }</b></p><p> if(ch!='@')</p><p><b> {</b></p><p> p=new struct strNode;</p><p> q->next=p;</p>&
110、lt;p><b> q=p;</b></p><p><b> j++;</b></p><p><b> }</b></p><p> }while(ch!='@');</p><p> getchar();</p><p&
111、gt; int num1, size=(j*64+i)*sizeof(char); //j為結(jié)構(gòu)體的個(gè)數(shù),i為不足一個(gè)結(jié)構(gòu)體的字符數(shù)</p><p><b> ////////</b></p><p> printf("文件長(zhǎng)度為:%d\n",size);</p><p> char judge='n
112、39;;</p><p><b> do{</b></p><p> printf("請(qǐng)輸入文件的英文名字:");</p><p> gets(name);</p><p> //scanf("%s",name);getchar();</p><p>
113、; printf("請(qǐng)輸入文件的擴(kuò)展名:");</p><p> gets(ext1);</p><p> //scanf("%s",ext1);getchar();</p><p> if(*ext1=='\0') strcpy(ext1,"txt");</p>&l
114、t;p> judge='y';</p><p> if(*name=='\0')</p><p><b> {</b></p><p> printf("錯(cuò)誤!文件名不能為空!\n");</p><p> printf("是否放棄此文件[Y/N
115、] ");</p><p> scanf("%c",&judge);getchar();</p><p> if( (judge=='y') || (judge=='Y') ) </p><p><b> return;</b></p><p>
116、<b> }</b></p><p> }while( (judge=='n') || (judge=='N') );</p><p> fseek(fp,512L,0);</p><p> fread(&emptytable,sizeof(struct empty),1,fp);</p&g
117、t;<p> rewind(fp);</p><p> num=emptytable.filenum;</p><p> /*for(i=0;i<num;i++){</p><p> fread(&file[i],sizeof(struct filename),1,fp);</p><p> printf
118、("%s.%s\n",file[i].name,file[i].ext);</p><p><b> }*/</b></p><p> for (i=0;i<num;i++){</p><p> if((strcmp(file[i].name,name)==0) && (strcmp(file[i
119、].ext,ext1)==0)){</p><p> printf("! 錯(cuò)誤 ! 兩個(gè)文件名不能相同\n");</p><p><b> return;</b></p><p><b> }</b></p><p><b> }</b></p
120、><p> num1=size/512;</p><p> if((size%512)>0) num1=num1+1;</p><p> strcpy(file[num].name,name);</p><p> //printf("%d%s%s",num,file[num].name,name);</
121、p><p> strcpy(file[num].ext,ext1);</p><p> file[num].size = size;</p><p> file[num].Amount=num1;</p><p> int sign=0 ,n=0;</p><p><b> //空間分配</b&g
122、t;</p><p> for(int m=2 ; m <=10-num1; m++){ //****************************</p><p> if(emptytable.map[m]==0){ </p><p> for(n=file[num].Amount; n>0; n--){</p>
123、<p> if(emptytable.map[m+n-1]==1){</p><p><b> sign=1;</b></p><p><b> break;</b></p><p><b> }//if</b></p><p><b> }//
124、for</b></p><p> if(sign==0)break;</p><p><b> m+=n-1;</b></p><p><b> sign=0;</b></p><p><b> }//if</b></p><p>&
125、lt;b> }//for</b></p><p> if(m<=10-num1)</p><p> file[num].i = m; //***********************************************</p><p> else
126、 </p><p><b> {</b></p><p> printf("空間不足!\n");</p><p><b> return;</b></p><p><b> }</b></p><p&
127、gt; for(j=0;j < file[num].Amount;j++){</p><p> emptytable.map[m+j]=1;</p><p><b> }</b></p><p> num=num+1;</p><p> emptytable.filenum=num;</p>
128、<p> WriteFile();//寫目錄及位示圖</p><p><b> //寫數(shù)據(jù)</b></p><p> fseek(fp,file[num-1].i * 512L,0);</p><p> long int cycle=file[num-1].size;</p><p> p=head
129、; i=0;</p><p> for(j=cycle;j>0;j--)</p><p> { ch=p->word[i++];</p><p> fwrite(&ch,sizeof(char),1,fp);</p><p><b> if(i>=64)</b></p>
130、<p><b> { i=0;</b></p><p> p=p->next;</p><p><b> }</b></p><p> // cycle--;</p><p><b> }</b></p><p> re
131、wind(fp);</p><p> for(j=0,i=0;i<num;i++,j++){</p><p> //printf("斷點(diǎn)%d\n",i);</p><p> fread(&file[i],sizeof(struct filename),1,fp);</p><p> //printf(
132、"%s\n",file[i].name);</p><p> printf("%s.%s",file[i].name,file[i].ext);</p><p> if(j==5) printf("\n");</p><p><b> }</b></p><
133、p> fclose(fp);</p><p><b> }</b></p><p> void rename(){</p><p><b> FILE *fp;</b></p><p> if((fp=fopen("filesys","rb+"
134、))==NULL){</p><p> printf("can not open file\npleace Initialization at first\n");</p><p><b> exit(0);</b></p><p><b> }</b></p><p>
135、 char sourse[12],sext[8],object[12],oext[8];</p><p> int num,sign;</p><p> printf("請(qǐng)輸入需要重命名的文件名和擴(kuò)展名:\n");</p><p> gets(sourse);</p><p> gets(sext);</p
136、><p> printf("請(qǐng)輸入新的名字和擴(kuò)展名:\n");</p><p> gets(object);</p><p> gets(oext);</p><p> fseek(fp,512L,0);</p><p> fread(&emptytable,sizeof(struct
137、 empty),1,fp);</p><p> num = emptytable.filenum;</p><p> rewind(fp);</p><p> for(int i=0;i<num;i++){</p><p> fread(&file[i],sizeof(struct filename),1,fp);<
138、;/p><p><b> }</b></p><p><b> sign = 0;</b></p><p> for( i = 0;i<num;i++){</p><p> if((strcmp(file[i].name,sourse)==0) && (strcmp(fil
139、e[i].ext,sext)==0)){</p><p><b> sign = 1;</b></p><p> strcpy(file[i].name,object);</p><p> if(*oext == '\0')</p><p> strcpy(file[i].ext,file[i]
140、.ext);</p><p><b> else</b></p><p> strcpy(file[i].ext,oext);</p><p><b> break;</b></p><p><b> }//if</b></p><p><
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計(jì)簡(jiǎn)單文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)--簡(jiǎn)單文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)---文件系統(tǒng)的模擬
- 操作系統(tǒng)課程設(shè)計(jì)--模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)--樹形目錄文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--多級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--多級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)---模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)-模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--多級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--虛擬文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--多級(jí)文件系統(tǒng).doc
- 操作系統(tǒng)課程設(shè)計(jì)--基于linux的模擬文件系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)二級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)--二級(jí)文件系統(tǒng)設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)二級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)(文件系統(tǒng)管理)
- 操作系統(tǒng)課程設(shè)計(jì)----二級(jí)文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)--多用戶多級(jí)目錄文件系統(tǒng)實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)---多用戶多級(jí)目錄文件系統(tǒng)的實(shí)現(xiàn)
評(píng)論
0/150
提交評(píng)論