版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 課程設(shè)計任務(wù)書</b></p><p> 計算機科學(xué)與技術(shù) 專業(yè) 年級 班 </p><p><b> 設(shè)計題目</b></p><p><b> 文件管理系統(tǒng)設(shè)計</b></p>&
2、lt;p><b> 主要內(nèi)容</b></p><p> 設(shè)計一個簡單的文件管理系統(tǒng)來模擬文件操作命令的執(zhí)行</p><p><b> 具體要求</b></p><p> 設(shè)計和調(diào)試一個簡單的文件管理系統(tǒng)來模擬文件管理,使學(xué)生對主要文件操作命令的實質(zhì)和執(zhí)行過程有比較深入的了解,掌握它們的基本實施方法。具體要求如
3、下:</p><p> ⑴設(shè)計一個支持n個用戶的文件系統(tǒng),每個用戶可擁有多個文件;</p><p> ?、撇捎枚壔蚨壱陨系亩嗉壩募夸浌芾?;</p><p> ?、菍ξ募?yīng)設(shè)置存取控制保護方式,如“只能執(zhí)行”、“允許讀”、“允許寫”等;</p><p> ?、认到y(tǒng)的外部特征應(yīng)接近于真實系統(tǒng),可設(shè)置下述文件操作命令:建立文件、打開文件、關(guān)
4、閉文件、刪除文件、讀文件、寫文件、復(fù)制文件、查詢目錄。</p><p> ?、赏ㄟ^鍵盤(或鼠標(biāo))使用該文件系統(tǒng),系統(tǒng)應(yīng)顯示操作命令的執(zhí)行結(jié)果。</p><p><b> 進度安排</b></p><p> 2012-9-3-----2012-9-6 確定系統(tǒng)的總體設(shè)計方案:即系統(tǒng)包括哪些功能模塊,每個模塊的實現(xiàn)算法,并畫出相應(yīng)的流程圖.
5、同時編寫相應(yīng)的設(shè)計文檔;</p><p> 2012-9-6-----2012-9-12 編寫程序代碼并調(diào)試,再將調(diào)試通過的各個子模塊進行集成調(diào)試;</p><p> 2012-2-12----2012-9-16 歸納文檔資料,完成課程設(shè)計說明書,參加課程設(shè)計答辯</p><p><b> 完成后應(yīng)上交的材料</b></p>
6、;<p> 在課程設(shè)計完成后需要提交的成果和有關(guān)文檔資料包括:</p><p><b> 課程設(shè)計的說明書。</b></p><p> 課程設(shè)計有關(guān)源程序及可運行程序(光盤或電子郵件)。</p><p><b> 總評成績:</b></p><p> 指導(dǎo)教師
7、 簽名日期 年 月 日</p><p> 系 主 任 審核日期 年 月 日</p><p> 一、本設(shè)計目的及基本思想</p><p> 本課程設(shè)計目的是實現(xiàn)樹型目錄結(jié)構(gòu)文件系統(tǒng),在實現(xiàn)過程中利用了二叉樹,</p><p> 其中每個節(jié)點都有父指針,子指針和兄弟指針,其中子指針指
8、向該目錄下的第一個子節(jié)點,而該子節(jié)點的父指針則指向它的上級目錄。目錄下各子節(jié)點用兄弟指針連接起來。</p><p> 文件夾打開是則把文件夾名稱及其地址壓入打開文件夾棧,文件關(guān)閉則把文件夾名稱及其地址從打開文件夾棧中拋出。</p><p> 文件打開則把文件的名稱及其父指針寫到文件列表同時置文件打開標(biāo)志為1,文件關(guān)閉則把文件從打開列表中刪除,同時置文件打開指針為0,文件讀取和寫入都要檢
9、查文件是否在文件打開列表中,未打開文件不能讀寫,只讀文件不能寫,只寫文件不能讀。</p><p> 文件夾和文件創(chuàng)建,文件夾和文件的創(chuàng)建首先檢驗?zāi)夸浭欠駷榭?,為空則把文件夾或文件連接到該目錄下,不為空則把檢查目錄下是否有同名文件夾或文件,有則提示創(chuàng)建不成功,沒有則把文件夾或文件連接到該目錄下的最后一個子節(jié)點,作為它的兄弟節(jié)點。</p><p> 文件夾和文件的刪除,文件夾下沒有打開的文
10、件或文件沒有打開才能刪除,否則刪除失敗,刪除文件夾時利用了中序歷遍來刪除子樹。</p><p><b> 二、系統(tǒng)設(shè)計</b></p><p> 2.1 系統(tǒng)基本結(jié)構(gòu)</p><p> 系統(tǒng)基本結(jié)構(gòu)如下圖:</p><p><b> 圖1系統(tǒng)基本結(jié)構(gòu)圖</b></p><
11、p> root為根結(jié)點,root下有五個用戶,每個用戶有自己的文件夾或文件,系統(tǒng)初始化時為每個用戶創(chuàng)建一個file1文件。文件夾內(nèi)容只有名稱和打開標(biāo)志。文件除了名稱和打開標(biāo)志,還有文件的訪問權(quán)限,文件類型以及文件長度。其中文件的訪問權(quán)限、文件類型、文件長度單獨作為一個結(jié)構(gòu)體,其它和文件夾結(jié)構(gòu)體相同,也同用一個結(jié)構(gòu)體。</p><p> 打開文件列表的結(jié)構(gòu)體包括文件名和文件的父節(jié)點地址,打開文件夾的棧中包
12、括文件夾名稱及其地址</p><p> 2.2 系統(tǒng)數(shù)據(jù)結(jié)構(gòu)</p><p> //普通文件的結(jié)構(gòu)體</p><p> struct file{</p><p> char type; //文件類型0-文本文件 1-可執(zhí)行文件 2-記錄型文件</p><p> char right; //文件的權(quán)
13、限0-可讀 1-可寫 2-可讀可寫</p><p> int f_length; //文件長度</p><p><b> };</b></p><p> typedef struct file File;</p><p> //文件夾或文件的結(jié)構(gòu)體</p><p> struct
14、FCB {</p><p> char kind; //kind='1'為文件夾 kind='2'為文件</p><p> char name[20]; //文件夾或文件名稱</p><p> bool open;</p><p> File if_file;</p><
15、;p> struct FCB *parent;</p><p> struct FCB *brother;</p><p> struct FCB *child;</p><p><b> };</b></p><p> typedef struct FCB Ff;</p><p>
16、; //root和fcp為全局變量</p><p> Ff *root;//根節(jié)點</p><p> Ff *fcp=null;//判斷是否有拷貝文件</p><p><b> //打開項的結(jié)構(gòu)體</b></p><p> typedef struct{</p><p> char n
17、ame[20];//名稱</p><p> Ff *node; //指針,打開的是文件夾記錄文件夾的地址,是文件記錄文件的父節(jié)點地</p><p><b> }opened;</b></p><p> int OPFO=0; //記錄文件夾打開數(shù)目,最多20</p><p> opened folde
18、ropened[20];//記錄文件打開文件夾</p><p> int OPFI=0; //記錄文件打開數(shù)目,最多20</p><p> opened fileopened[20];//記錄打開文件</p><p> 2.3 函數(shù)清單及部分函數(shù)算法流程圖</p><p> //函數(shù)聲明/////////////////////
19、////////</p><p> void init();//初始化創(chuàng)建根節(jié)點</p><p> void initopen();//初始化打開文件列表或打開文件夾文件列表</p><p> Ff* creat(Ff *parent,char name[20],char kind);//創(chuàng)建文件或文件夾</p><p> void
20、delet(Ff *parent,char delname[20],char kind);//刪除文件文件夾</p><p> void delSub(Ff *delp); //刪除子樹(配合刪除文件夾使用)</p><p> void openfolder(Ff *parent, char name[20]);//打開文件夾</p&g
21、t;<p> void openfile(Ff *parent, char name[20]);//打開文件</p><p> void closefo(); //關(guān)閉文件夾</p><p> void closefile(char name[20]); //關(guān)閉文件</p><p&
22、gt; void read(Ff*parent,char name[20]); //讀文件</p><p> void write(char name[20]); // 寫文件</p><p> void show(); //顯示初始界面</p><p> void init
23、file(); //初始化每個用戶,為每個用戶創(chuàng)建一個file1文件</p><p> int ishaveopen(Ff *bedel); //判斷文件夾下是否有打開的文件或文件夾</p><p> void filecpy(Ff *parent,char name[20]);//文件復(fù)制函數(shù)</p>&
24、lt;p> void pastefile(Ff *parent); //文件粘貼</p><p><b> 主函數(shù)流程圖:</b></p><p> 主函數(shù)開始執(zhí)行時,先初始化。初始化包括創(chuàng)建root根目錄,創(chuàng)建user0~user4五個用戶,為每個用戶創(chuàng)建一個file1的文件。</p><p> 初始化完畢
25、后,顯示選擇用戶和退出系統(tǒng)兩個操作,列出用戶。選擇1則進入選擇用戶界面,選擇用戶后則列出用戶目錄下的內(nèi)容。同時顯示操作界面。選擇操作后,執(zhí)行相應(yīng)的操作。執(zhí)行完畢回到選擇操作界面。</p><p> 創(chuàng)建文件夾或文件函數(shù)流程圖(creat()):</p><p> 創(chuàng)建文件或文件夾首先通過主函數(shù)選擇操作來傳遞參數(shù),kind=1創(chuàng)建文件夾,kind=2創(chuàng)建文件。文件或文件夾名稱是由用戶輸入
26、。文件或文件夾的父節(jié)點由folderopened[OPFO-1].node來傳遞。</p><p> 如果當(dāng)前目錄下由同名文件或同名文件夾則創(chuàng)建文件或創(chuàng)建文件夾不成功。</p><p> 當(dāng)前目錄是空目錄則創(chuàng)建的文件或文件夾是當(dāng)前目錄的首個子節(jié)點。Parent指針指向當(dāng)前目錄,當(dāng)前目錄的child指針指向文件或文件夾。</p><p> 當(dāng)前目錄不為空,則把文
27、件或文件夾連接到當(dāng)前目錄下最后的子節(jié)點后面,作為最后的兄弟節(jié)點。</p><p> 刪除文件或文件夾函數(shù)delet()的流程圖:</p><p> 同樣刪除文件或文件夾的類型參數(shù)由用戶選擇操作時傳遞。Kind=1刪除文件夾,kind=2刪除文件。名稱也由用戶輸入。</p><p> 文件在打開列表或文件夾中有打開的文件,文件或文件夾不能刪除,目錄下沒有該文件或
28、文件夾刪除失敗,刪除失敗時返回相應(yīng)的信息。</p><p> 如果目錄下有該文件或文件夾,而且文件沒打開,或文件夾中沒有打開的文件,則刪除該釋放該節(jié)點或該子樹。返回刪除成功信息。</p><p><b> 流程圖如下:</b></p><p> 文件打開函數(shù)及其流程圖openfile():</p><p> 文件
29、打開,只能但開當(dāng)前目錄下的文件,首先查找文件是否在打開文件列表中,在則返回文件已經(jīng)在打開文件列表中的信息,不是,則查看當(dāng)前目錄有沒有該文件,有則打開,同時把文件名及其父節(jié)點地址寫到文件隊列中,置文件打開標(biāo)志為1。返回打開成功信息。</p><p> 文件被打開后,返回上層目錄或到別的目錄下,文件不會從打開文件列表中刪除。除非在文件所在的目錄下執(zhí)行關(guān)閉文件操作關(guān)閉此文件文件才從打開文件列表中刪除。</p&g
30、t;<p><b> 其流程圖如下:</b></p><p> 文件刪除函數(shù)說明及其流程圖:</p><p> 文件刪除,只能對當(dāng)前的目錄下的文件進行操作。文件不在打開隊列中,關(guān)閉失敗,返回提示信息。在打開列表中則關(guān)閉文件,置文件打開標(biāo)志為0。</p><p><b> 流程圖如下:</b></
31、p><p> 文件夾打開和關(guān)閉函數(shù)說明:</p><p> 文件夾打開,只能打開當(dāng)前目錄下的文件夾打開后,文件夾名稱及其節(jié)點地址寫到文件夾堆棧中(如果打開的是同一個目錄,不用寫打開文件夾堆棧),同時列出文件夾目錄下的內(nèi)容。關(guān)閉文件夾(返回上級目錄)則把當(dāng)前目錄從打開文件夾堆棧中拋出,同時打開上級目錄。</p><p> 以下是打開文件夾和關(guān)閉文件夾函數(shù)源程序:&l
32、t;/p><p><b> 打開文件夾:</b></p><p> void openfolder(Ff *parent, char name[20])</p><p><b> {</b></p><p> Ff *select,*beopen;</p><p> i
33、f(!parent->child) //目錄為空</p><p><b> {</b></p><p> printf("沒有此文件!");</p><p><b> return;</b></p><p><b> }</b>&
34、lt;/p><p> beopen=parent->child;</p><p> while(beopen) //尋找要打開的文件夾</p><p><b> {</b></p><p> if(beopen->kind=='1')</p><p>&
35、lt;b> {</b></p><p> if(strcmp(beopen->name,name)==0) //文件夾被找到</p><p><b> {</b></p><p><b> break;</b></p><p><b> }</b&
36、gt;</p><p><b> }</b></p><p> if(!beopen->brother)</p><p><b> {</b></p><p> printf("文件夾不存在!\n");</p><p><b>
37、return;</b></p><p><b> }</b></p><p> beopen=beopen->brother;</p><p><b> }</b></p><p> //while end</p><p> if(!beopen-
38、>child)</p><p><b> {</b></p><p> printf("該文件夾是空的!\n");</p><p> if(OPFO>=2)</p><p><b> {</b></p><p> if(foldero
39、pened[OPFO-2].node==parent)</p><p><b> {</b></p><p> if(strcmp(folderopened[OPFO-1].name,name)==0)</p><p><b> return;</b></p><p><b> }
40、</b></p><p><b> }</b></p><p> folderopened[OPFO].node=beopen;</p><p> strcpy(folderopened[OPFO].name,beopen->name);</p><p><b> OPFO++;<
41、;/b></p><p><b> return;</b></p><p><b> }</b></p><p> if(beopen->child)</p><p><b> {</b></p><p> select=beope
42、n->child;</p><p> while(select) //列出文件夾下的內(nèi)容</p><p><b> {</b></p><p> for(int i=0;i<3&&select;i++)</p><p><b> {</b></p>
43、<p> printf("%s",select->name);</p><p> if(select->kind=='1')</p><p><b> {</b></p><p> printf("(文件夾)\t");</p><p>
44、;<b> }</b></p><p> if(select->kind=='2')</p><p><b> {</b></p><p> if(select->if_file.type=='0')</p><p><b> {<
45、;/b></p><p> printf("(文本文件 %dk)\t",select->if_file.f_length);</p><p><b> }</b></p><p> if(select->if_file.type=='1')</p><p>&l
46、t;b> {</b></p><p> printf("(可執(zhí)行文件 %dk)\t",select->if_file.f_length);</p><p><b> }</b></p><p> if(select->if_file.type=='2')</p>
47、;<p><b> {</b></p><p> printf("(記錄型文件 %dk)\t",select->if_file.f_length);</p><p><b> }</b></p><p><b> }</b></p><
48、;p> select=select->brother;</p><p><b> }</b></p><p> printf("\n");</p><p><b> }</b></p><p> if(OPFO>=2)</p><p
49、><b> {</b></p><p> if(folderopened[OPFO-2].node==parent) //打開文件夾堆棧中已有,不寫堆棧</p><p><b> {</b></p><p> if(strcmp(folderopened[OPFO-1].name,name)==0)</
50、p><p><b> return;</b></p><p><b> }</b></p><p><b> }</b></p><p> folderopened[OPFO].node=beopen; //打開文件夾不在堆棧,寫堆棧 </p><
51、;p> strcpy(folderopened[OPFO].name,beopen->name);</p><p><b> OPFO++;</b></p><p><b> return;</b></p><p><b> }</b></p><p>&l
52、t;b> }</b></p><p> ///////////////////////////////////////////////</p><p><b> 關(guān)閉文件夾源程序:</b></p><p><b> ///文件夾關(guān)閉</b></p><p> void c
53、losefo()</p><p><b> {</b></p><p> if(OPFO==2) //返回到根結(jié)點,不能再執(zhí)行返回操作</p><p><b> {</b></p><p> printf("這里是根節(jié)點!\n");</p><p&
54、gt;<b> show();</b></p><p><b> OPFO--;</b></p><p><b> return;</b></p><p><b> }</b></p><p><b> OPFO--;</b>
55、;</p><p> openfolder(folderopened[OPFO-2].node,folderopened[OPFO-1].name);</p><p> folderopened[OPFO].node=null;</p><p><b> }</b></p><p> //////////////
56、//////////////////////// </p><p> 刪除子樹函數(shù)(void delSub())和判斷文件夾下是否有文件打開函數(shù)(int ishaveopen())</p><p> 這兩個函數(shù)都是用來輔助刪除文件夾函數(shù)的,刪除子樹函數(shù)用后序歷遍樹的方法 刪除子樹是遞歸函數(shù)。Ishaveopen()函數(shù)利用先序歷遍樹的方法判斷文件夾下是否有打開文件,也是遞歸函數(shù)。當(dāng)有打
57、開文件是返回1,否則返回0。</p><p> 刪除子樹函數(shù)源程序:</p><p><b> //刪除子樹</b></p><p> void delSub(Ff *delp)</p><p><b> {</b></p><p> if(delp->bro
58、ther) delSub(delp->brother);//歷遍brother子樹</p><p> if(delp->child) delSub(delp->child);//歷遍child子樹</p><p> free(delp);//釋放節(jié)點</p><p><b> }</b></p><p
59、> 判斷文件夾下是否有打開文件函數(shù)源程序:</p><p> //輔助del函數(shù)中的刪除文件夾</p><p> int ishaveopen(Ff *bedel)</p><p><b> {</b></p><p> if(bedel->open==true)</p><p&
60、gt;<b> {</b></p><p><b> return 1;</b></p><p><b> }</b></p><p> if(bedel->brother)</p><p> ishaveopen(bedel->brother);<
61、/p><p> if(bedel->child)</p><p> ishaveopen(bedel->child);</p><p><b> else</b></p><p><b> return 0;</b></p><p><b> }&
62、lt;/b></p><p> 文件復(fù)制及其粘貼函數(shù)的說明:</p><p> 文件復(fù)制,在當(dāng)前目錄下查找要復(fù)制的文件,若查找不到,返回信息,拷貝失敗。</p><p> 若查找到了,則創(chuàng)建一個新節(jié)點,把要復(fù)制的文件的信息寫道新節(jié)點的相應(yīng)的項里。</p><p> 文件粘貼,首先判斷fcp是否為空,空則表明沒有復(fù)制文件,不能執(zhí)行
63、粘貼操作。</p><p> 不為空,則查找當(dāng)前目錄下是否有同名文件,有則詢問用戶是否要覆蓋已存在的文件,</p><p> 是則把復(fù)制代替要被覆蓋的文件,并釋放被覆蓋文件的資源。否則退出。若是沒有和復(fù)制文件同名的文件則把文件連到目錄下的最后的子節(jié)點后。</p><p> 以下是粘貼文件的源程序:</p><p> ///粘貼文件//
64、////</p><p> void pastefile(Ff *parent)</p><p><b> {</b></p><p> Ff *select,*cover;</p><p><b> char opt;</b></p><p><b>
65、if(!fcp)</b></p><p><b> {</b></p><p> printf("沒有被拷貝的文件,請先拷貝文件!\n");</p><p><b> return;</b></p><p><b> }</b></
66、p><p> if(!parent->child) //目錄是空目錄</p><p><b> {</b></p><p> fcp->child=parent;</p><p> parent->child=fcp;</p><p><b> fcp=null;
67、</b></p><p> printf("粘貼成功!\n");</p><p><b> return;</b></p><p><b> }</b></p><p> select=parent->child;</p><p>
68、; if(select->kind=='2')//覆蓋的文件是目錄下第一個子節(jié)點</p><p><b> {</b></p><p> if(strcmp(select->name,fcp->name)==0)</p><p><b> {</b></p><
69、p> printf("該目錄下已經(jīng)有此文件!是否覆蓋(y/n)?");</p><p> getchar();</p><p> scanf("%c",&opt);</p><p> if(opt=='Y'||opt=='y')</p><p>&l
70、t;b> {</b></p><p> fcp->brother=select->brother;</p><p> fcp->child=select->child;</p><p> fcp->parent=select->parent;</p><p> parent-&g
71、t;child=fcp;</p><p> select->brother=null;</p><p> select->child=null;</p><p> select->parent=null;</p><p> free(select);</p><p> printf(&quo
72、t;覆蓋成功!\n");</p><p><b> fcp=null;</b></p><p><b> return;</b></p><p><b> }</b></p><p><b> else</b></p>&l
73、t;p><b> return;</b></p><p><b> }</b></p><p><b> }</b></p><p> while(select->brother)//查找目錄下是否有同名文件</p><p><b> {<
74、/b></p><p> if(select->brother->kind=='2')</p><p><b> {</b></p><p> if(strcmp(select->brother->name,fcp->name)==0)</p><p><b
75、> {</b></p><p> printf("該目錄下已經(jīng)有此文件!是否覆蓋(y/n)?");</p><p> getchar();</p><p> scanf("%c",&opt);</p><p> if(opt=='Y'||opt==
76、39;y')//覆蓋同名文件</p><p><b> {</b></p><p> cover=select->brother;</p><p> fcp->brother=cover->brother;</p><p> fcp->child=cover->child;&
77、lt;/p><p> fcp->parent=cover->parent;</p><p> select->brother=fcp;</p><p> free(cover);</p><p> printf("覆蓋成功!\n");</p><p><b> fc
78、p=null;</b></p><p><b> return;</b></p><p><b> }</b></p><p><b> else </b></p><p><b> return;</b></p><
79、;p><b> }</b></p><p><b> }</b></p><p> select=select->brother;</p><p><b> }</b></p><p> select->brother=fcp;//目錄下沒有同名文件
80、</p><p><b> fcp=null;</b></p><p><b> return;</b></p><p><b> } </b></p><p><b> 三、程序運行效果</b></p><p><b
81、> 初始界面:</b></p><p><b> 選擇1進入界面:</b></p><p> 選擇用戶后進入的界面:</p><p> 用戶1下有文件file1</p><p> 建立文件成功和失敗圖示:</p><p> 建立同名文件時,創(chuàng)建出錯不同名文件創(chuàng)建成功。
82、</p><p> 刪除文件成功及失敗圖示:</p><p> 1、刪除文件file1,file1沒打開。刪除成功:</p><p> 目錄只剩下file2。</p><p> 2、刪除ff文件,目錄下沒有此文件,刪除失敗:</p><p> 3、文件file2打開后刪除,刪除失?。?lt;/p>&
83、lt;p> 創(chuàng)建文件夾成功和失敗圖示:</p><p> 1、創(chuàng)建文件夾new,目錄中沒有new文件夾,創(chuàng)建成功:</p><p> 2、在創(chuàng)建文件夾new,目錄中有文件夾new,創(chuàng)建失?。?lt;/p><p> 刪除文件夾成功及其失敗圖示:</p><p> 1、首先建立多一個文件夾,folder在folder里創(chuàng)建文件new并
84、打開文件new。</p><p><b> 此時提示刪除失?。?lt;/b></p><p> 2、關(guān)閉文件new后,刪除成功:</p><p> 此時用戶下少了文件夾folder。</p><p><b> 文件拷貝及其粘貼:</b></p><p> 1、首先我們在n
85、ew文件夾下創(chuàng)建一個hello文件,并拷貝hello文件。</p><p><b> 拷貝成功:</b></p><p> 2、在回到上層目錄useer1,把文件粘貼在此目錄下,粘貼成功:</p><p> 此時user1下多了文件hello。</p><p> 寫讀文件成功及失敗圖示:</p>&
86、lt;p> 1、讀文件file2,file2沒打開,讀失?。?lt;/p><p> 2、打開文件file2,然后讀取,讀取成功:</p><p> 3、寫文件,寫file2,因為file2已經(jīng)打開,所以寫成功:</p><p> 4、關(guān)了文件file2后,再寫文件file2,不成功:</p><p><b> 顯示路徑:
87、</b></p><p><b> 進入文件夾:</b></p><p> 1、進入文件夾new,為了更清楚看到路徑,進入文件夾new后用s命令顯示當(dāng)前路徑:</p><p> 2、返回操作,返回user1目錄,為了更清楚看到路徑,返回后用s命令顯示當(dāng)前路徑:</p><p><b> 四、
88、總結(jié)體會</b></p><p> 本次課程設(shè)計,本人選擇了樹型結(jié)構(gòu)文件系統(tǒng)的設(shè)計這一題目。剛剛開始時,不知道怎么設(shè)計,只知道大概的結(jié)構(gòu)。后來認真閱讀課本有關(guān)的知識,知道怎樣設(shè)計結(jié)構(gòu)體才方便文件操作。知道怎樣設(shè)計后,寫程序時也遇到很多的障礙,特別是指針的改接和指向和出錯處理。此時深感自己編程能力的不足,經(jīng)過多次修改,終于設(shè)計好了該設(shè)計。</p><p> 通過該課程設(shè)計,使
89、我更了解了課本知識,鞏固了課本知識,同時也使我的編程能力有了一定的提高。袁節(jié)膅薂羄肅蒃薁蚃芀荿薀螆肅芅蕿袈羋膁蚈羀肁蒀蚇蝕襖莆蚇螂肀莂蚆羅袂羋蚅蚄膈膄蚄螇羈蒂蚃衿膆莈螞羈罿芄螁蟻膄膀螁螃羇葿螀裊膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃螞肂莈蒂螄羋芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羈莀蒈羃膇芆蕆蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃蠆羆艿薃袁節(jié)膅薂羄肅蒃薁蚃芀荿薀螆肅芅蕿袈羋膁蚈羀肁蒀蚇蝕襖莆蚇螂肀莂蚆羅袂羋蚅蚄膈膄蚄螇羈蒂蚃衿膆莈螞羈罿芄螁蟻膄膀螁
90、螃羇葿螀裊膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃螞肂莈蒂螄羋芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羈莀蒈羃膇芆蕆蚃羀膂蒆螅膅蒁薅袇羈莇襖羋蕆袇螀芇蕿蝕聿芆艿蒃肅芅蒁螈羈芄薃薁袆芃芃螆螂芃蒞蕿肁節(jié)蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈螞螂羂薁袈肀肁芀蟻羆肁莃袆袂肀薅蠆袈聿蚇蒂膇肈莇螇肅肇葿薀罿肆薂螆裊肅芁薈螁膅莃螄聿膄蒆薇羅膃蚈螂羈膂莈蚅袇膁蒀袀螃膀薂蚃肂腿節(jié)衿羈腿莄螞襖羋蕆袇螀芇蕿蝕聿芆艿蒃肅芅蒁螈羈芄薃薁袆芃芃螆螂芃蒞蕿肁
91、節(jié)蒈螅羇莁薀薈袃莀艿螃蝿荿莂薆膈莈薄袁肄莇蚆蚄羀莇莆袀袆羃蒈螞螂羂薁袈肀肁芀蟻羆肁莃袆袂肀薅蠆袈聿蚇蒂</p><p> 芀荿薀螆肅芅蕿袈羋膁蚈羀肁蒀蚇蝕襖莆蚇螂肀莂蚆羅袂羋蚅蚄膈膄蚄螇羈蒂蚃衿膆莈螞羈罿芄螁蟻膄膀螁螃羇葿螀裊膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃螞肂莈蒂螄羋芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羈莀蒈羃膇芆蕆蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃蠆羆艿薃袁節(jié)膅薂羄肅蒃薁蚃芀荿薀螆肅芅蕿袈羋膁蚈羀肁蒀蚇蝕襖莆
92、蚇螂肀莂蚆羅袂羋蚅蚄膈膄蚄螇羈蒂蚃衿膆莈螞羈罿芄螁蟻膄膀螁螃羇葿螀裊膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃螞肂莈蒂螄羋芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羈莀蒈羃膇芆蕆蚃羀膂蒆螅膅蒁薅袇羈莇薄罿膄芃薃蠆羆艿薃袁節(jié)膅薂羄肅蒃薁蚃芀荿薀螆肅芅蕿袈羋膁蚈羀肁蒀蚇蝕襖莆蚇螂肀莂蚆羅袂羋蚅蚄膈膄蚄螇羈蒂蚃衿膆莈螞羈罿芄螁蟻膄膀螁螃羇葿螀裊膃蒅蝿肈羆莁螈螇芁芇莄袀肄膃莄羂艿蒂莃螞肂莈蒂螄羋芄蒁袆肀膀蒀罿袃薈葿螈聿蒄葿袁羈莀蒈羃膇芆蕆蚃羀膂蒆螅膅蒁薅袇羈莇
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計說明
- 操作系統(tǒng)課程設(shè)計——操作系統(tǒng)課程設(shè)計模擬操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計理發(fā)師問題說明書
- 操作系統(tǒng)課程設(shè)計說明書--基于linux的進程之間通信
- 操作系統(tǒng)課程設(shè)計-- 操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計指導(dǎo)書
- 內(nèi)存管理(操作系統(tǒng))操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計題目
- 操作系統(tǒng)課程設(shè)計報告
- 操作系統(tǒng)課程設(shè)計論文
- 操作系統(tǒng)課程設(shè)計 (4)
- 操作系統(tǒng)課程設(shè)計1
- 課程設(shè)計報告--操作系統(tǒng)
- linux操作系統(tǒng)課程設(shè)計
評論
0/150
提交評論