




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、中北大學(xué)操作系統(tǒng)課程設(shè)計說 明 書 學(xué) 院、系:軟件學(xué)院專 業(yè):軟件工程學(xué) 生 姓 名:任彬?qū)W 號:0921010132設(shè) 計 題 目:基于Linux的模擬文件系統(tǒng)的設(shè)計與實現(xiàn) 起 迄 日 期: 2011年12月22日- 2012年1月7日指 導(dǎo) 教 師:康珺 2012 年 1月 7 日1.需求分析本次課程設(shè)計題目為“基于Linux的模擬文件系統(tǒng)的設(shè)計與實現(xiàn)”,要求在linux開源環(huán)境下,通過使用系統(tǒng)庫函數(shù)以及操作命令,模擬實現(xiàn)典型文件系統(tǒng),實現(xiàn)文件的各項基本操作,以此加深對所學(xué)文件操作的了解以及操作方法的特點。通過模擬文件系統(tǒng)的實現(xiàn),深入理解操作系
2、統(tǒng)中文件系統(tǒng)的理論知識,加深教材中的重要算法的理解,同時通過編程實現(xiàn)這些算法,更好地掌握操作系統(tǒng)的遠(yuǎn)離及實現(xiàn)方法,提高綜合運(yùn)用各專業(yè)課知識的能力。根據(jù)實驗要求可將系統(tǒng)功能簡述如下:(1)設(shè)計一個10個用戶的文件系統(tǒng)。每個用戶最多可以保存10個文件,一次運(yùn)行用戶可打開多個文件。(2)程序采用二級文件目錄。(即設(shè)置主目錄(MFD)和用戶文件目錄(UFD)。另外,可打開文件設(shè)置指針。(3)為了方便實現(xiàn),對文件的讀寫作了簡化。在執(zhí)行讀寫命令時,只需改讀寫指針。并不進(jìn)行實際的讀寫操作。(4)實現(xiàn)目錄的相關(guān)操作:改變目錄(CD),創(chuàng)建目錄(MD),顯示目錄(DIR),刪除目錄(RD)。(5)實現(xiàn)文件的相關(guān)
3、操作:打開文件(open),關(guān)閉文件(close),創(chuàng)建一個新文件(create),刪除一個文件(delete),寫文件(write),讀文件(read)。(6)考慮特殊情況如:目錄不存在時,給出錯誤信息;不能用cd進(jìn)入文件;命令之中不能有空格(如 ex it,給出錯誤提示);新建目錄或文件時的問題、重名問題、目錄或文件的名字長度限制、目錄或文件的名字中包含不合法字符(注意空格)、刪除目錄或文件時的問題、刪除不存在的文件或目錄給出錯誤提示、刪除目錄時目錄不為空(如果該目錄為空,則可刪除,否則給出是否做刪除提示,刪除操作將該目錄下的全部文件和子目錄都刪除)、進(jìn)入到某個目錄下,卻要刪除本目錄或上級
4、目錄、不能用delete刪除目錄、不能用RD刪除文件等。.2.總體設(shè)計本系統(tǒng)以C語言為編程基礎(chǔ),通過調(diào)用linux環(huán)境下的庫函數(shù)實現(xiàn)各功能模塊。<1>整個系統(tǒng)采用“主函數(shù)-子函數(shù)”結(jié)構(gòu)。系統(tǒng)初始化無誤后,運(yùn)行主函數(shù),在主函數(shù)中通過輸入?yún)?shù)的變化調(diào)用相關(guān)功能子函數(shù)。各子函數(shù)之間采用平行結(jié)構(gòu),只與主函數(shù)有聯(lián)系,整個系統(tǒng)共由17個子模塊實現(xiàn)。系統(tǒng)流程圖如下:開始用戶登錄判斷是否存在YESNO刪除文件創(chuàng)建子目錄改變子目錄列出子目錄關(guān)閉文件打開文件創(chuàng)建文件讀文件寫文件是否退出結(jié)束NOYES各模塊按功能可分為三類:(1)文件初始化。void initfile()(初始化文件系統(tǒng)); void
5、format()(格式化); void enter()(進(jìn)入文件系統(tǒng))。(2)目錄管理。int create(char *name) (創(chuàng)建文件); int open(char *name) (打開文件); int close(char *name) (關(guān)閉文件); int write(int fd,char *buf,int len) (讀文件); int read(int fd,char *buf) (讀文件); int del(char *name) (刪除文件)。(3)文件管理。int mkdir(char *name) (創(chuàng)建子目錄); int rmdir(char *name) (
6、刪除子目錄); void dir()(顯示當(dāng)前目錄的子目錄); int cd(char *name) (更改當(dāng)前目錄); void print()(顯示當(dāng)前路徑); void show()(輸出提示信息)。<2>為實現(xiàn)文件的模擬訪問以及控制,利用disk.dat虛擬磁盤的管理調(diào)度,保存運(yùn)行過程中各項操作以及數(shù)據(jù)。各個子函數(shù)在功能實現(xiàn)時,首先必須利用相應(yīng)指針定位到disk.dat文件,操作完成后將運(yùn)行參數(shù)保存到文件中。<2>結(jié)構(gòu)體設(shè)計(1)二級目錄實現(xiàn)。為實現(xiàn)二級目錄,定義如下結(jié)構(gòu)體變量file,content。typedef struct file char name1
7、0; struct file *next;File;file結(jié)構(gòu)體用于保存文件名,并通過指向下一個文件的指針形成單向鏈表。typedef struct contentchar name10;File *file;int f_num;struct content *next;Content;Content結(jié)構(gòu)體用于保存目錄名,此外,一方面通過指向下一個目錄的指針形成單向鏈表,另一方面通過指向下一級的文件指針實現(xiàn)連接該目錄頭文件的作用,以此實現(xiàn)二級目錄索引。(2)用戶訪問實現(xiàn)。為實現(xiàn)用戶訪問,定義如下結(jié)構(gòu)體user。typedef struct user char name10; char psw
8、10; Content *con;struct user *next;user結(jié)構(gòu)體用于保存用戶名和密碼,通過指向下一個用戶的指針將注冊用戶形成單向鏈表。用戶登錄時,進(jìn)行用戶名、密碼的判斷,若正確,跳轉(zhuǎn)到主界面,否則通過指針的鏈接到下一個用戶信息,重復(fù)上述過程。(3)虛擬磁盤管理的實現(xiàn)。為實現(xiàn)虛擬磁盤的管理調(diào)度,定義結(jié)構(gòu)體fatitem,direct,opentable。struct fatitem /* size 8*/ int item; /*存放文件下一個磁盤的指針*/ char em_disk; /*磁盤塊是否空閑標(biāo)志位 0 空閑*/ ; Fatitem結(jié)構(gòu)體用于文件配置表fat表的結(jié)
9、構(gòu)定義。struct direct struct FCB char name9; /*文件/目錄名 8位*/ char property; /*屬性 1位目錄 0位普通文件*/ int size; /*文件/目錄字節(jié)數(shù)、盤塊數(shù))*/ int firstdisk; /*文件/目錄 起始盤塊號*/ int next; /*子目錄起始盤塊號*/ int sign; /*1是根目錄 0不是根目錄*/ directitemMSD+2; -; direct結(jié)構(gòu)體用于目錄項結(jié)構(gòu)的定義,其中嵌套的FCB用于文件控制塊的定義。struct opentable struct openttableitem char
10、 name9; /*文件名*/ int firstdisk; /*起始盤塊號*/ int size; /*文件的大小*/ openitemMOFN; int cur_size; /*當(dāng)前打文件的數(shù)目*/ ;Opentable結(jié)構(gòu)體用于文件打開表項結(jié)構(gòu)的定義。3.詳細(xì)設(shè)計結(jié)構(gòu)化程序設(shè)計的模式是自頂向下,逐步求精的過程。當(dāng)設(shè)計一個程序時,需要將需要將求解問題逐步分解成能解決局部問題的更小的功能模塊,直到每一個局部模塊都不能再分為止,每一個最小化的模塊對應(yīng)一個相應(yīng)的函數(shù)。函數(shù)的功能應(yīng)該最小化,即每個函數(shù)只完成一個簡單的功能。根據(jù)模塊功能能最小化的思想,我們將程序劃分為17個子模塊,每個模塊只負(fù)責(zé)完成
11、一個功能,他們分別為void initfile()(初始化文件系統(tǒng)); void format()(格式化); void enter()(進(jìn)入文件系統(tǒng)); void halt()(退出文件系統(tǒng)); int create(char *name) (創(chuàng)建文件); int open(char *name) (打開文件); int close(char *name) (關(guān)閉文件); int write(int fd,char *buf,int len) (讀文件); int read(int fd,char *buf) (讀文件); int del(char *name) (刪除文件); int mk
12、dir(char *name) (創(chuàng)建子目錄); int rmdir(char *name) (刪除子目錄); void dir()(顯示當(dāng)前目錄的子目錄); int cd(char *name) (更改當(dāng)前目錄); void print()(顯示當(dāng)前路徑); void show()(輸出提示信息)以及main函數(shù)。各個函數(shù)通過相互嵌套調(diào)用,最終完成實現(xiàn)linux下模擬文件的設(shè)計和實現(xiàn)。(1)初始化文件系統(tǒng):initfile()函數(shù)主要源碼為:void initfile() fdisk = (char *)malloc(MEM_D_SIZE*sizeof(char); format(); 使用
13、庫函數(shù)Malloc 向系統(tǒng)申請分配指定size個字節(jié)的內(nèi)存空間。,用來儲存char類型文件,同時初始化文件。(2)格式化文件:void format();主要源碼為:void format() int i; FILE *fp; fat = (struct fatitem *)(fdisk+DISKSIZE); /*計算FAT表地址,引導(dǎo)區(qū)向后偏移 1k)*/ /*-初始化FAT表-*/ fat0.item=-1; /*引導(dǎo)塊*/ fat0.em_disk='1' for(i=1;i<ROOT_DISK_NO-1;i+) /*存放 FAT表的磁盤塊號*/ fati.item
14、=i+1; fati.em_disk='1' /fatROOT_DISK_NO-1.item=-1; /fatROOT_DISK_NO-1.em_disk='1' fatROOT_DISK_NO.item=-1; /*存放根目錄的磁盤塊號*/ fatROOT_DISK_NO.em_disk='1' for(i=ROOT_DISK_NO+1;i<DISK_NUM;i+) fati.item = -1; fati.em_disk = '0' /*-*/ root = (struct direct *)(fdisk+DISKSIZ
15、E+FATSIZE); /*根目錄的地址*/ /*初始化目錄*/ /*-指向當(dāng)前目錄的目錄項-*/ root->directitem0.sign = 1; root->directitem0.firstdisk = ROOT_DISK_NO; strcpy(root->,"."); root->directitem0.next = root->directitem0.firstdisk; root->perty = '1' root->directitem
16、0.size = ROOT_DISK_SIZE; /*-指向上一級目錄的目錄項-*/ root->directitem1.sign = 1; root->directitem1.firstdisk = ROOT_DISK_NO; strcpy(root->,"."); root->directitem1.next = root->directitem0.firstdisk; root->perty = '1' root->directitem1.size
17、= ROOT_DISK_SIZE; if(fp = fopen("disk.dat","wb")=NULL) printf("Error:n Cannot open file n"); return; for(i=2;i<MSD+2;i+) /*-子目錄初始化為空-*/ root->directitemi.sign = 0; root->directitemi.firstdisk = -1; strcpy(root->,""); root->direct
18、itemi.next = -1; root->perty = '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!
19、 n"); fclose(fp); 本函數(shù)用來計算在程序中已定義的struct fatitem *fat; /*FAT表*/ struct direct *root; /*根目錄*/; struct direct *cur_dir; /*當(dāng)前目錄*/的地址及對他們進(jìn)行初始化,方便以后的使用。通過指針定義的方法,將結(jié)構(gòu)體中的成員進(jìn)行定義。(3)void enter()(進(jìn)入文件系統(tǒng));主要源碼為:void enter() FILE *fp; int i; fdisk = (char *)malloc(MEM_D_SIZE*sizeof(char); /*申請 1M空間*/ if(fp=
20、fopen("disk.dat","rb")=NULL) printf("Error:nCannot open filen"); return; if(!fread(fdisk,MEM_D_SIZE,1,fp) /*把磁盤文件disk.dat 讀入虛擬磁盤空間(內(nèi)存)*/ printf("Error:nCannot read filen"); exit(0); fat = (struct fatitem *)(fdisk+DISKSIZE); /*找到FAT表地址*/ root = (struct direct *
21、)(fdisk+DISKSIZE+FATSIZE);/*找到根目錄地址*/ fclose(fp); /*-初始化用戶打開表-*/ for(i=0;i<MOFN;i+) strcpy(u_,""); u_opentable.openitemi.firstdisk = -1; u_opentable.openitemi.size = 0; u_opentable.cur_size = 0; cur_dir = root; /*當(dāng)前目錄為根目錄*/ bufferdir = (char *)malloc(DIR_LENGTH*s
22、izeof(char); strcpy(bufferdir,"Root:"); 本函數(shù)完成進(jìn)入文件系統(tǒng)的功能,首先定義一個文件指針并分配空間,然后進(jìn)行if語句判斷,以只讀的方式打開二進(jìn)制文件,如果無法打開,顯示錯誤,打開成功,則檢測把是否磁盤文件disk.dat 讀入虛擬磁盤空間(內(nèi)存),失敗同樣顯示錯誤,當(dāng)兩項條件句滿足要求時,找到fat表地址,找到根目錄地址,打開文件并顯示目錄。(4) void halt()(退出文件系統(tǒng));主要源碼為:void halt() FILE *fp; int i; if(fp=fopen("disk.dat","
23、;wb")=NULL) printf("Error:nCannot open filen"); return; if(!fwrite(fdisk,MEM_D_SIZE,1,fp) /*把虛擬磁盤空間(內(nèi)存)內(nèi)容讀入磁盤文件disk.dat */ printf("Error:nFile write error!n"); fclose(fp); free(fdisk); free(bufferdir); return;本函數(shù)完成關(guān)閉文件的功能,與進(jìn)入文件系統(tǒng)相同,首先定義一個文件指針并分配空間,然后進(jìn)行if語句判斷,是否建立了只允許寫的文件disk
24、.dat,如果文件不存在,顯示錯誤,文件存在成功,則檢測把是否把虛擬磁盤空間(內(nèi)存)內(nèi)容讀入磁盤文件disk.dat,失敗同樣顯示錯誤,當(dāng)兩項條件句滿足要求時,關(guān)閉文件,釋放的緩存空間。(5)int create(char *name) (創(chuàng)建文件)主要源碼為:int create(char *name) int i,j; if(strlen(name)>8) /*文件名大于 8位*/ return(-1); for(j=2;j<MSD+2;j+) /*檢查創(chuàng)建文件是否與已存在的文件重名*/ if(!strcmp(cur_dir->,name)
25、 break; if(j<MSD+2) /*文件已經(jīng)存在*/ return(-4); for(i=2;i<MSD+2;i+) /*找到第一個空閑子目錄*/ if(cur_dir->directitemi.firstdisk=-1) break; if(i>=MSD+2) /*無空目錄項*/ return(-2); if(u_opentable.cur_size>=MOFN) /*打開文件太多*/ return(-3); for(j=ROOT_DISK_NO+1;j<DISK_NUM;j+) /*找到空閑盤塊 j 后退出*/ if(fatj.em_disk=&
26、#39;0') break; if(j>=DISK_NUM) return(-5); fatj.em_disk = '1' /*將空閑塊置為已經(jīng)分配*/ /*-填寫目錄項-*/ strcpy(cur_dir->,name); cur_dir->directitemi.firstdisk = j; cur_dir->directitemi.size = 0; cur_dir->directitemi.next = j; cur_dir->perty = '0'
27、 /*-*/ fd = open(name); return 0; 本函數(shù)實現(xiàn)創(chuàng)建文件的功能,首先進(jìn)行條件判斷,檢測文件名長度,檢測文件是否有重名,其中文件名不能超過八位,文件不能有重名。如果兩項條件滿足,則采用順序法查找符合條件的空閑子目錄,創(chuàng)建文件,用指針定義法將結(jié)構(gòu)體定義,創(chuàng)建文件;如果沒有空閑目錄項或打開文件過多則返回一個錯誤的值。(6)int open(char *name) (打開文件)主要源碼為:int open(char *name) int i, j; for(i=2;i<MSD+2;i+) /*文件是否存在*/ if(!strcmp(cur_dir->direc
28、,name) break; if(i>=MSD+2) return(-1); /*-是文件還是目錄-*/ if(cur_dir->perty='1') return(-4); /*-文件是否打開-*/ for(j=0;j<MOFN;j+) if(!strcmp(u_,name) break; if(j<MOFN) /*文件已經(jīng)打開*/ return(-2); if(u_opentable.cur_size>=MOFN) /*文件打開太多*/ retu
29、rn(-3); /*-查找一個空閑用戶打開表項-*/ for(j=0;j<MOFN;j+) if(u_opentable.openitemj.firstdisk=-1) break; /*-填寫表項的相關(guān)信息-*/ u_opentable.openitemj.firstdisk = cur_dir->directitemi.firstdisk; strcpy(u_,name); u_opentable.openitemj.size = cur_dir->directitemi.size; u_opentable.cur_size
30、+; /*-返回用戶打開表表項的序號-*/ return(j); 本函數(shù)用來實現(xiàn)打開文件的功能,首先檢測輸入的文件名是否存在,不存在,則不做任何運(yùn)行,存在則繼續(xù)下一步邏輯判斷。接著檢測輸入的是文件名還是目錄,是目錄,返回一個錯誤的值,是文件名,則監(jiān)測文件是否打開,打開則不作操作,未打開則尋找一個空閑用戶,打開文件,返回打開文件的序號。(7) int close(char *name) (關(guān)閉文件)主要源碼為:int close(char *name) int i; for(i=0;i<MOFN;i+) if(!strcmp(u_,name)
31、 break; if(i>=MOFN) return(-1); /*-清空該文件的用戶打開表項的內(nèi)容-*/ strcpy(u_,""); u_opentable.openitemi.firstdisk = -1; u_opentable.openitemi.size = 0; u_opentable.cur_size-; return 0; 本函數(shù)實現(xiàn)關(guān)閉文件的功能,同時清空該文件的用戶打開表項的內(nèi)容。(8)int write(int fd,char *buf,int len) (讀文件);主要源碼為:int write
32、(int fd, char *buf, int len) char *first; int item, i, j, k; int ilen1, ilen2, modlen, temp; /*-用 $ 字符作為空格 # 字符作為換行符-*/ char Space = 32; char Endter= 'n' for(i=0;i<len;i+) if(bufi = '$') bufi = Space; else if(bufi = '#') bufi = Endter; /*-讀取用戶打開表對應(yīng)表項第一個盤塊號-*/ item = u_open
33、table.openitemfd.firstdisk; /*-找到當(dāng)前目錄所對應(yīng)表項的序號-*/ for(i=2;i<MSD+2;i+) if(cur_dir->directitemi.firstdisk=item) break; temp = i; /*-存放當(dāng)前目錄項的下標(biāo)-*/ /*-找到的item 是該文件的最后一塊磁盤塊-*/ while(fatitem.item!=-1) item =fatitem.item; /*-查找該文件的下一盤塊-*/ /*-計算出該文件的最末地址-*/ first = fdisk+item*DISKSIZE+u_opentable.openi
34、temfd.size%DISKSIZE; /*-如果最后磁盤塊剩余的大小大于要寫入的文件的大小-*/ if(DISKSIZE-u_opentable.openitemfd.size%DISKSIZE>len) strcpy(first,buf); u_opentable.openitemfd.size = u_opentable.openitemfd.size+len; cur_dir->directitemtemp.size = cur_dir->directitemtemp.size+len; else for(i=0;i<(DISKSIZE-u_opentable
35、.openitemfd.size%DISKSIZE);i+) /*寫一部分內(nèi)容到最后一塊磁盤塊的剩余空間(字節(jié))*/ firsti = buf i; /*-計算分配完最后一塊磁盤的剩余空間(字節(jié)) 還剩下多少字節(jié)未存儲-*/ ilen1 = len-(DISKSIZE-u_opentable.openitemfd.size%DISKSIZE); ilen2 = ilen1/DISKSIZE; modlen = ilen1%DISKSIZE; if(modlen>0) ilen2 = ilen2+1; /*-還需要多少塊磁盤塊-*/ for(j=0;j<ilen2;j+) for(i
36、=ROOT_DISK_NO+1;i<DISK_NUM;i+)/*尋找空閑磁盤塊*/ if(fati.em_disk='0') break; if(i>=DISK_NUM) /*-如果磁盤塊已經(jīng)分配完了-*/ return(-1); first = fdisk+i*DISKSIZE; /*-找到的那塊空閑磁盤塊的起始地址-*/ if(j=ilen2-1) /*-如果是最后要分配的一塊-*/ for(k=0;k<len-(DISKSIZE-u_opentable.openitemfd.size%DISKSIZE)-j*DISKSIZE;k+) firstk = b
37、ufk; else/*-如果不是要最后分配的一塊-*/ for(k=0;k<DISKSIZE;k+) firstk =bufk; fatitem.item = i; /*-找到一塊后將它的序號存放在上一塊的指針中-*/ fati.em_disk = '1' /*-置找到的磁盤快的空閑標(biāo)志位為已分配-*/ fati.item = -1; /*-它的指針為 -1 (即沒有下一塊)-*/ /*-修改長度-*/ u_opentable.openitemfd.size = u_opentable.openitemfd.size+len; cur_dir->directitem
38、temp.size = cur_dir->directitemtemp.size+len; return 0; 本函數(shù)用來實現(xiàn)寫文件的功能。文件打開后,進(jìn)行寫操作,更改文件內(nèi)容。首先檢測寫入的內(nèi)容,檢測是否存在$與#的字符,若有,則將$ 字符作為空格 # 字符作為換行符。然后讀取用戶打開表對應(yīng)表項第一個盤塊號,找到當(dāng)前目錄所對應(yīng)表項的序號,找到該文件的最后一塊磁盤塊,計算出文件的最末地址,計算寫入文件大小,如果最后磁盤塊剩余的大小大于要寫入的文件的大小,則寫入文件,如果最后磁盤塊剩余的大小小于要寫入的文件的大小,將磁盤寫滿后,計算出還剩下多少字節(jié)未存儲,還需多少磁盤,在鏈表中尋找空閑磁盤
39、塊,繼續(xù)寫入剩余字節(jié),找到后,記錄此磁盤的首地址指針,寫入文件,磁盤寫滿后將后一個磁盤的起始地址的指針放入到前一磁盤的指針中,完成文件的鏈接,就這樣直到文件寫完為止,最后修改文件長度。(9) int read(int fd,char *buf) (讀文件);主要源碼為:int read(int fd, char *buf) int len = u_opentable.openitemfd.size; char *first; int i, j, item; int ilen1, modlen; item = u_opentable.openitemfd.firstdisk; ilen1 = l
40、en/DISKSIZE; modlen = len%DISKSIZE; if(modlen!=0) ilen1 = ilen1+1; /*-計算文件所占磁盤的塊數(shù)-*/ first = fdisk+item*DISKSIZE; /*-計算文件的起始位置-*/ for(i=0;i<ilen1;i+) if(i=ilen1-1) /*-如果在最后一個磁盤塊-*/ for(j=0;j<len-i*DISKSIZE;j+) bufi*DISKSIZE+j = firstj; else /*-不在最后一塊磁盤塊-*/ for(j=0;j<len-i*DISKSIZE;j+) bufi*
41、DISKSIZE+j = firstj; item = fatitem.item; /*-查找下一盤塊-*/ first = fdisk+item*DISKSIZE; return 0; 本函數(shù)完成簡單的磁盤讀的功能,首先計算文件所占磁盤的塊數(shù),找到文件的起始位置,然后根據(jù)指針依次訪問磁盤,完成整個文件的讀功能。(10) int del(char *name) (刪除文件);主要源碼為:int del(char *name) int i,cur_item,item,temp; for(i=2;i<MSD+2;i+) /*-查找要刪除文件是否在當(dāng)前目錄中-*/ if(!strcmp(cur
42、_dir->,name) break; cur_item = i; /*-用來保存目錄項的序號,供釋放目錄中-*/ if(i>=MSD+2) /*-如果不在當(dāng)前目錄中-*/ return(-1); if(cur_dir->directitemcur_perty!='0') /*-如果刪除的(不)是目錄-*/ return(-3); for(i=0;i<MOFN;i+) /*-如果文件打開,則不能刪除,退出-*/ if(!strcmp(u_,name) retu
43、rn(-2); item = cur_dir->directitemcur_item.firstdisk;/*-該文件的起始盤塊號-*/ while(item!=-1) /*-釋放空間,將FAT表對應(yīng)項進(jìn)行修改-*/ temp = fatitem.item; fatitem.item = -1; fatitem.em_disk = '0' item = temp; /*-釋放目錄項-*/ cur_dir->directitemcur_item.sign = 0; cur_dir->directitemcur_item.firstdisk = -1; strcp
44、y(u_opentable.openitemcur_,""); cur_dir->directitemcur_item.next = -1; cur_dir->directitemcur_perty = '0' cur_dir->directitemcur_item.size = 0; return 0; 本函數(shù)用來刪除文件,首先檢測要刪除文件是否在當(dāng)前目錄中,無則返回錯誤信息,有則將文件的序號提供,查找文件地址,監(jiān)測文件是否打開,如果打開,則提示文件已打開,無法刪除,沒打開則釋放文件內(nèi)存空間,釋放目錄項,
45、同時修改Fat表。(11) int mkdir(char *name) (創(chuàng)建子目錄);主要源碼為:int mkdir(char *name) int i,j; struct direct *cur_mkdir; if(!strcmp(name,".") return(-4); if(!strcmp(name,".") return(-4); if(strlen(name)>8) /*-如果目錄名長度大于 8位-*/ return(-1); for(i=2;i<MSD+2;i+) /*-如果有空閑目錄項退出-*/ if(cur_dir->
46、;directitemi.firstdisk=-1) break; if(i>=MSD+2) /*-目錄/文件 已滿-*/ return(-2); for(j=2;j<MSD+2;j+) /*-判斷是否有重名-*/ if(!strcmp(cur_dir->,name) break; if(j<MSD+2) /*-如果有重名-*/ return(-3); for(j=ROOT_DISK_NO+1;j<DISK_NUM;j+) /*-找到空閑磁盤塊 j 后退出-*/ if(fatj.em_disk='0') break;
47、 if(j>=DISK_NUM) return(-5); fatj.em_disk='1' /*-將該空閑塊設(shè)置為已分配-*/ /*-填寫目錄項-*/ strcpy(cur_dir->,name); cur_dir->directitemi.firstdisk=j; cur_dir->directitemi.size=ROOT_DISK_SIZE; cur_dir->directitemi.next=j; cur_dir->perty='1' /*-所創(chuàng)目錄在虛擬磁
48、盤上的地址(內(nèi)存物理地址)-*/ cur_mkdir=(struct direct *)(fdisk+cur_dir->directitemi.firstdisk*DISKSIZE); /*-初始化目錄-*/ /*-指向當(dāng)前目錄的目錄項-*/ cur_mkdir->directitem0.sign=0; cur_mkdir->directitem0.firstdisk=cur_dir->directitemi.firstdisk; strcpy(cur_mkdir->,"."); cur_mkdir->di
49、rectitem0.next=cur_mkdir->directitem0.firstdisk; cur_mkdir->perty='1' cur_mkdir->directitem0.size=ROOT_DISK_SIZE; /*-指向上一級目錄的目錄項-*/ cur_mkdir->directitem1.sign=cur_dir->directitem0.sign; cur_mkdir->directitem1.firstdisk=cur_dir->directitem0.firstdisk; strcpy(cur_mkdir->,"."); cur_mkdir->directitem1.next=cur_mkdir->directitem1.firstdisk; cur_mkdir->perty='1' cur_mkdir-
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 中級經(jīng)濟(jì)師職業(yè)發(fā)展的路徑選擇試題及答案
- 2025屆梅州市蕉嶺縣數(shù)學(xué)三上期末監(jiān)測模擬試題含解析
- 工程經(jīng)濟(jì)與財務(wù)管理的聯(lián)系試題及答案
- 應(yīng)對市政工程考試的壓力應(yīng)對技巧試題及答案
- 設(shè)計色彩與視覺傳達(dá)
- 水利水電工程節(jié)能減排技術(shù)收獲與探討試題及答案
- 經(jīng)濟(jì)法概論復(fù)習(xí)試題及答案全解
- 濕法可降解醫(yī)療用品生產(chǎn)項目可行性研究報告模板-立項備案
- 經(jīng)濟(jì)學(xué)的歷史貢獻(xiàn)試題及答案
- 2024年水利水電工程綜合治理試題及答案
- 形勢與政策(貴州財經(jīng)大學(xué))知到智慧樹章節(jié)答案
- DL∕T 904-2015 火力發(fā)電廠技術(shù)經(jīng)濟(jì)指標(biāo)計算方法
- DL-T 1476-2023 電力安全工器具預(yù)防性試驗規(guī)程
- 中國戲曲劇種鑒賞智慧樹知到期末考試答案章節(jié)答案2024年上海戲劇學(xué)院等跨校共建
- 六年級趣味數(shù)學(xué)思維拓展題50道及答案
- T∕CNTAC 23-2018 醫(yī)護(hù)職業(yè)服裝
- 芯片生產(chǎn)全過程從沙子到封裝課件
- 水泥混凝土路面翻修施工方案完整
- 怡口軟水機(jī)中央凈水機(jī)安裝調(diào)試指南.
- 暖通畢業(yè)設(shè)計外文翻譯
- 小黃瓜種植觀察日記(課堂PPT)
評論
0/150
提交評論