操作系統(tǒng)課程設(shè)計簡單文件系統(tǒng)的實現(xiàn).doc
《操作系統(tǒng)課程設(shè)計簡單文件系統(tǒng)的實現(xiàn).doc》由會員分享,可在線閱讀,更多相關(guān)《操作系統(tǒng)課程設(shè)計簡單文件系統(tǒng)的實現(xiàn).doc(33頁珍藏版)》請在裝配圖網(wǎng)上搜索。
操作系統(tǒng)課程設(shè)計報告 小組編號: 小組成員: 一、課程設(shè)計概述: 1、題目:簡單文件系統(tǒng)的實現(xiàn) 2、實現(xiàn)內(nèi)容 (1) 在內(nèi)存中開辟一個虛擬磁盤空間作為文件存儲分區(qū),在其上實現(xiàn)一個簡單的基于多級目錄的單用戶單任務(wù)系統(tǒng)中的文件系統(tǒng)。在退出該文件系統(tǒng)的使用時,應(yīng)將該虛擬文件系統(tǒng)以一個Windows 文件的方式保存到磁盤上,以便下次可以再將它恢復(fù)到內(nèi)存的虛擬磁盤空間中。 (2) 文件存儲空間的分配可采用顯式鏈接分配或其他的辦法。 (3) 空閑磁盤空間的管理可選擇位示圖或其他的辦法。如果采用位示圖來管理文件存儲空間,并采用顯式鏈接分配方式,那么可以將位示圖合并到FAT中。 (4) 文件目錄結(jié)構(gòu)采用多級目錄結(jié)構(gòu)。為了簡單起見,可以不使用索引結(jié)點,其中的每個目錄項應(yīng)包含文件名、物理地址、長度等信息,還可以通過目錄項實現(xiàn)對文件的讀和寫的保護。 (5) 要求提供以下操作命令: l my_format:對文件存儲器進行格式化,即按照文件系統(tǒng)的結(jié)構(gòu)對虛擬磁盤空間進行布局,并在其上創(chuàng)建根目錄以及用于管理文件存儲空間等的數(shù)據(jù)結(jié)構(gòu)。 l my_mkdir:用于創(chuàng)建子目錄。 l my_rmdir:用于刪除子目錄。 l my_ls:用于顯示目錄中的內(nèi)容。 l my_cd:用于更改當(dāng)前目錄。 l my_create:用于創(chuàng)建文件。 l my_open:用于打開文件。 l my_close:用于關(guān)閉文件。 l my_write:用于寫文件。 l my_read:用于讀文件。 l my_rm:用于刪除文件。 l my_exitsys:用于退出文件系統(tǒng)。 2、 設(shè)計思路(主要算法描述、程序流程圖等): 1.系統(tǒng)主函數(shù)main() (1)對應(yīng)命令:無 (2)命令調(diào)用格式:無 (3)函數(shù)設(shè)計格式:void main() (4)功能:系統(tǒng)主函數(shù) (5)輸入:無 (6)輸出:無 (7)函數(shù)需完成的工作: ① 對前面定義的全局變量進行初始化; ② 調(diào)用startsys()進入文件系統(tǒng); ③ 列出文件系統(tǒng)提供的各項功能及命令調(diào)用格式; ④ 顯示命令行提示符,等待用戶輸入命令; ⑤ 將用戶輸入的命令保存到一個buf中; ⑥ 對buf中的內(nèi)容進行命令解析,并調(diào)用相應(yīng)的函數(shù)執(zhí)行用戶鍵入的命令; ⑦ 如果命令不是“my_exitsys”,則命令執(zhí)行完畢后轉(zhuǎn)④。 2. 進入文件系統(tǒng)函數(shù)startsys() (1)對應(yīng)命令:無 (2)命令調(diào)用格式:無 (3)函數(shù)設(shè)計格式:void startsys() (4)功能:由main()函數(shù)調(diào)用,進入并初始化我們所建立的文件系統(tǒng),以供用戶使用。 (5)輸入:無 (6)輸出:無。 (7)函數(shù)需完成的工作: ① 申請?zhí)摂M磁盤空間; ② 使用c語言的庫函數(shù)fopen()打開myfsys文件:若文件存在,則轉(zhuǎn)③;若文件不存在,則創(chuàng)建之,轉(zhuǎn)⑤ ③ 使用c語言的庫函數(shù)fread()讀入myfsys文件內(nèi)容到用戶空間中的一個緩沖區(qū)中,并判斷其開始的8個字節(jié)內(nèi)容是否為“10101010”(文件系統(tǒng)魔數(shù)),如果是,則轉(zhuǎn)④;否則轉(zhuǎn)⑤; ④ 將上述緩沖區(qū)中的內(nèi)容復(fù)制到內(nèi)存中的虛擬磁盤空間中;轉(zhuǎn)⑦ ⑤ 在屏幕上顯示“myfsys文件系統(tǒng)不存在,現(xiàn)在開始創(chuàng)建文件系統(tǒng)”信息,并調(diào)用my_format()對①中申請到的虛擬磁盤空間進行格式化操作。轉(zhuǎn)⑥; ⑥ 將虛擬磁盤中的內(nèi)容保存到myfsys文件中;轉(zhuǎn)⑦ ⑦ 使用c語言的庫函數(shù)fclose()關(guān)閉myfsys文件; ⑧ 初始化用戶打開文件表,將表項0分配給根目錄文件使用,并填寫根目錄文件的相關(guān)信息,由于根目錄沒有上級目錄,所以表項中的dirno和diroff分別置為5(根目錄所在起始塊號)和0;并將ptrcurdir指針指向該用戶打開文件表項。 ⑨ 將當(dāng)前目錄設(shè)置為根目錄。 3.磁盤格式化函數(shù)my_format() (1)對應(yīng)命令:my_format (2)命令調(diào)用格式:my_format (3)函數(shù)設(shè)計格式:void my_format() (4)功能:對虛擬磁盤進行格式化,布局虛擬磁盤,建立根目錄文件(或根目錄區(qū))。 (5)輸入:無 (6)輸出:無。 (7)函數(shù)需完成的工作: ① 將虛擬磁盤第一個塊作為引導(dǎo)塊,開始的8個字節(jié)是文件系統(tǒng)的魔數(shù),記為“10101010”;在之后寫入文件系統(tǒng)的描述信息,如FAT表大小及位置、根目錄大小及位置、盤塊大小、盤塊數(shù)量、數(shù)據(jù)區(qū)開始位置等信息; ② 在引導(dǎo)塊后建立兩張完全一樣的FAT表,用于記錄文件所占據(jù)的磁盤塊及管理虛擬磁盤塊的分配,每個FAT占據(jù)兩個磁盤塊;對于每個FAT中,前面5個塊設(shè)置為已分配,后面995個塊設(shè)置為空閑; ③ 在第二張FAT后創(chuàng)建根目錄文件root,將數(shù)據(jù)區(qū)的第1塊(即虛擬磁盤的第6塊)分配給根目錄文件,在該磁盤上創(chuàng)建兩個特殊的目錄項:“.”和“..”,其內(nèi)容除了文件名不同之外,其他字段完全相同。 4.更改當(dāng)前目錄函數(shù)my_cd() (1)對應(yīng)命令:my_cd (2)命令調(diào)用格式:my_cd dirname (3)函數(shù)設(shè)計格式:void my_cd(char *dirname) (4)功能:改變當(dāng)前目錄到指定的名為dirname的目錄。 (5)輸入: dirname:新的當(dāng)前目錄的目錄名; (6)輸出:無 (7)函數(shù)需完成的工作: ① 調(diào)用my_open()打開指定目錄名的父目錄文件,并調(diào)用do_read()讀入該父目錄文件內(nèi)容到內(nèi)存中; ② 在父目錄文件中檢查新的當(dāng)前目錄名是否存在,如果存在則轉(zhuǎn)③,否則返回,并顯示出錯信息; ③ 調(diào)用my_close()關(guān)閉①中打開的父目錄文件; ④ 調(diào)用my_close()關(guān)閉原當(dāng)前目錄文件; ⑤ 如果新的當(dāng)前目錄文件沒有打開,則打開該目錄文件;并將ptrcurdir指向該打開文件表項; ⑥ 設(shè)置當(dāng)前目錄為該目錄。 5.創(chuàng)建子目錄函數(shù)my_mkdir() (1)對應(yīng)命令:my_mkdir (2)命令調(diào)用格式:my_ mkdir dirname (3)函數(shù)設(shè)計格式:void my_mkdir(char *dirname) (4)功能:在當(dāng)前目錄下創(chuàng)建名為dirname的子目錄。 (5)輸入: dirname:新建目錄的目錄名。 (6)輸出:無。 (7)函數(shù)需完成的工作: ① 調(diào)用do_read()讀入當(dāng)前目錄文件內(nèi)容到內(nèi)存,檢查當(dāng)前目錄下新建目錄文件是否重名,若重名則返回,并顯示錯誤信息; ② 為新建子目錄文件分配一個空閑打開文件表項,如果沒有空閑表項則返回-1,并顯示錯誤信息; ③ 檢查FAT是否有空閑的盤塊,如有則為新建目錄文件分配一個盤塊,否則釋放①中分配的打開文件表項,返回,并顯示錯誤信息; ④ 在當(dāng)前目錄中為新建目錄文件尋找一個空閑的目錄項或為其追加一個新的目錄項;需修改當(dāng)前目錄文件的長度信息,并將當(dāng)前目錄文件的用戶打開文件表項中的fcbstate置為1; ⑤ 準(zhǔn)備好新建目錄文件的FCB的內(nèi)容,文件的屬性為目錄文件,以覆蓋寫方式調(diào)用do_write()將其填寫到對應(yīng)的空目錄項中; ⑥ 在新建目錄文件所分配到的磁盤塊中建立兩個特殊的目錄項“.”和“..”目錄項,方法是:首先在用戶空間中準(zhǔn)備好內(nèi)容,然后以截斷寫或者覆蓋寫方式調(diào)用do_write()將其寫到③中分配到的磁盤塊中; ⑦ 返回。 6.刪除子目錄函數(shù)rmdir() (1)對應(yīng)命令:my_ rmdir (2)命令調(diào)用格式:my_ rmdir dirname (1)函數(shù)設(shè)計格式:void my_rmdir(char *dirname) (2)功能:在當(dāng)前目錄下刪除名為dirname的子目錄。 (3)輸入: dirname:欲刪除目錄的目錄名。 (4)輸出:無。 (5)函數(shù)需完成的工作: ① 調(diào)用do_read()讀入當(dāng)前目錄文件內(nèi)容到內(nèi)存,檢查當(dāng)前目錄下欲刪除目錄文件是否存在,若不存在則返回,并顯示錯誤信息; ② 檢查欲刪除目錄文件是否為空(除了“.”和“..”外沒有其他子目錄和文件),可根據(jù)其目錄項中記錄的文件長度來判斷,若不為空則返回,并顯示錯誤信息; ③ 檢查該目錄文件是否已經(jīng)打開,若已打開則調(diào)用my_close()關(guān)閉掉; ④ 回收該目錄文件所占據(jù)的磁盤塊,修改FAT; ⑤ 從當(dāng)前目錄文件中清空該目錄文件的目錄項,且free字段置為0:以覆蓋寫方式調(diào)用do_write()來實現(xiàn); ⑥ 修改當(dāng)前目錄文件的用戶打開表項中的長度信息,并將表項中的fcbstate置為1; ⑦ 返回。 7.顯示目錄函數(shù)my_ls() (1)對應(yīng)命令:my_ls (2)命令調(diào)用格式:my_ls (3)函數(shù)設(shè)計格式:void my_ls(void) (4)功能:顯示當(dāng)前目錄的內(nèi)容(子目錄和文件信息)。 (5)輸入:無 (6)輸出:無 (7)函數(shù)需完成的工作: ① 調(diào)用do_read()讀出當(dāng)前目錄文件內(nèi)容到內(nèi)存; ② 將讀出的目錄文件的信息按照一定的格式顯示到屏幕上; ③ 返回。 8.創(chuàng)建文件函數(shù)my_create() (1)對應(yīng)命令:my_create (2)命令調(diào)用格式:my_create filename (3)函數(shù)設(shè)計格式:int my_create (char *filename) (4)功能:創(chuàng)建名為filename的新文件。 (5)輸入: filename:新建文件的文件名,可能包含路徑。 (6)輸出:若創(chuàng)建成功,返回該文件的文件描述符(文件打開表中的數(shù)組下標(biāo));否則返回-1。 (7)函數(shù)需完成的工作: ① 為新文件分配一個空閑打開文件表項,如果沒有空閑表項則返回-1,并顯示錯誤信息; ② 若新文件的父目錄文件還沒有打開,則調(diào)用my_open()打開;若打開失敗,則釋放①中為新建文件分配的空閑文件打開表項,返回-1,并顯示錯誤信息; ③ 調(diào)用do_read()讀出該父目錄文件內(nèi)容到內(nèi)存,檢查該目錄下新文件是否重名,若重名則釋放①中分配的打開文件表項,并調(diào)用my_close()關(guān)閉②中打開的目錄文件;然后返回-1,并顯示錯誤信息; ④ 檢查FAT是否有空閑的盤塊,如有則為新文件分配一個盤塊,否則釋放①中分配的打開文件表項,并調(diào)用my_close()關(guān)閉②中打開的目錄文件;返回-1,并顯示錯誤信息; ⑤ 在父目錄中為新文件尋找一個空閑的目錄項或為其追加一個新的目錄項;需修改該目錄文件的長度信息,并將該目錄文件的用戶打開文件表項中的fcbstate置為1; ⑥ 準(zhǔn)備好新文件的FCB的內(nèi)容,文件的屬性為數(shù)據(jù)文件,長度為0,以覆蓋寫方式調(diào)用do_write()將其填寫到⑤中分配到的空目錄項中; ⑦ 為新文件填寫①中分配到的空閑打開文件表項,fcbstate字段值為0,讀寫指針值為0; ⑧ 調(diào)用my_close()關(guān)閉②中打開的父目錄文件; ⑨ 將新文件的打開文件表項序號作為其文件描述符返回。 9.刪除文件函數(shù)my_rm() (1)對應(yīng)命令:my_rm (2)命令調(diào)用格式:my_rm filename (3)函數(shù)設(shè)計格式:void my_rm(char *filename) (4)功能:刪除名為filename的文件。 (5)輸入: filename:欲刪除文件的文件名,可能還包含路徑。 (6)輸出:無。 (7)函數(shù)需完成的工作: ① 若欲刪除文件的父目錄文件還沒有打開,則調(diào)用my_open()打開;若打開失敗,則返回,并顯示錯誤信息; ② 調(diào)用do_read()讀出該父目錄文件內(nèi)容到內(nèi)存,檢查該目錄下欲刪除文件是否存在,若不存在則返回,并顯示錯誤信息; ③ 檢查該文件是否已經(jīng)打開,若已打開則關(guān)閉掉; ④ 回收該文件所占據(jù)的磁盤塊,修改FAT; ⑤ 從文件的父目錄文件中清空該文件的目錄項,且free字段置為0:以覆蓋寫方式調(diào)用do_write()來實現(xiàn);; ⑥ 修改該父目錄文件的用戶打開文件表項中的長度信息,并將該表項中的fcbstate置為1; ⑦ 返回。 10.打開文件函數(shù)my_open() (1)對應(yīng)命令:my_open (2)命令調(diào)用格式:my_open filename (3)函數(shù)設(shè)計格式:int my_open(char *filename) (4)功能:打開當(dāng)前目錄下名為filename的文件。 (5)輸入: filename:欲打開文件的文件名 (6)輸出:若打開成功,返回該文件的描述符(在用戶打開文件表中表項序號);否則返回-1。 (7)函數(shù)需完成的工作: ① 檢查該文件是否已經(jīng)打開,若已打開則返回-1,并顯示錯誤信息; ② 調(diào)用do_read()讀出父目錄文件的內(nèi)容到內(nèi)存,檢查該目錄下欲打開文件是否存在,若不存在則返回-1,并顯示錯誤信息; ③ 檢查用戶打開文件表中是否有空表項,若有則為欲打開文件分配一個空表項,若沒有則返回-1,并顯示錯誤信息; ④ 為該文件填寫空白用戶打開文件表表項內(nèi)容,讀寫指針置為0; ⑤ 將該文件所分配到的空白用戶打開文件表表項序號(數(shù)組下標(biāo))作為文件描述符fd返回。 11.關(guān)閉文件函數(shù)my_close() (1)對應(yīng)命令:my_close (2)命令調(diào)用格式:my_close fd (3)函數(shù)設(shè)計格式:void my_close(int fd) (4)功能:關(guān)閉前面由my_open()打開的文件描述符為fd的文件。 (5)輸入: fd:文件描述符。 (6)輸出:無。 (7)函數(shù)需完成的工作: ① 檢查fd的有效性(fd不能超出用戶打開文件表所在數(shù)組的最大下標(biāo)),如果無效則返回-1; ② 檢查用戶打開文件表表項中的fcbstate字段的值,如果為1則需要將該文件的FCB的內(nèi)容保存到虛擬磁盤上該文件的目錄項中,方法是:打開該文件的父目錄文件,以覆蓋寫方式調(diào)用do_write()將欲關(guān)閉文件的FCB寫入父目錄文件的相應(yīng)盤塊中; ③ 回收該文件占據(jù)的用戶打開文件表表項(進行清空操作),并將topenfile字段置為0; ④ 返回。 12.寫文件函數(shù)my_write() (1)對應(yīng)命令:my_write (2)命令調(diào)用格式:my_write fd (3)函數(shù)設(shè)計格式:int my_write(int fd) (4)功能:將用戶通過鍵盤輸入的內(nèi)容寫到fd所指定的文件中。磁盤文件的讀寫操作都必須以完整的數(shù)據(jù)塊為單位進行,在寫操作時,先將數(shù)據(jù)寫在緩沖區(qū)中,緩沖區(qū)的大小與磁盤塊的大小相同,然后再將緩沖區(qū)中的數(shù)據(jù)一次性寫到磁盤塊中;讀出時先將一個磁盤塊中的內(nèi)容讀到緩沖區(qū)中,然后再傳送到用戶區(qū)。本實例為了簡便起見,沒有設(shè)置緩沖區(qū)管理,只是在讀寫文件時由用戶使用malloc()申請一塊空間作為緩沖區(qū),讀寫操作結(jié)束后使用free()釋放掉。 寫操作常有三種方式:截斷寫、覆蓋寫和追加寫。截斷寫是放棄原來文件的內(nèi)容,重新寫文件;覆蓋寫是修改文件在當(dāng)前讀寫指針?biāo)傅奈恢瞄_始的部分內(nèi)容;追加寫是在原文件的最后添加新的內(nèi)容。在本實例中,輸入寫文件命令后,系統(tǒng)會出現(xiàn)提示讓用戶選擇其中的一種寫方式,并將隨后鍵盤輸入的內(nèi)容按照所選的方式寫到文件中,鍵盤輸入內(nèi)容通過CTR+Z鍵(或其他設(shè)定的鍵)結(jié)束。 (5)輸入: fd: open()函數(shù)的返回值,文件的描述符; (6)輸出:實際寫入的字節(jié)數(shù)。 (7)函數(shù)需完成的工作: ① 檢查fd的有效性(fd不能超出用戶打開文件表所在數(shù)組的最大下標(biāo)),如果無效則返回-1,并顯示出錯信息; ② 提示并等待用戶輸入寫方式:(1:截斷寫;2:覆蓋寫;3:追加寫) ③ 如果用戶要求的寫方式是截斷寫,則釋放文件除第一塊外的其他磁盤空間內(nèi)容(查找并修改FAT表),將內(nèi)存用戶打開文件表項中文件長度修改為0,將讀寫指針置為0并轉(zhuǎn)④;如果用戶要求的寫方式是追加寫,則修改文件的當(dāng)前讀寫指針位置到文件的末尾,并轉(zhuǎn)④;如果寫方式是覆蓋寫,則直接轉(zhuǎn)④; ④ 提示用戶:整個輸入內(nèi)容通過CTR+Z鍵(或其他設(shè)定的鍵)結(jié)束;用戶可分多次輸入寫入內(nèi)容,每次用回車結(jié)束; ⑤ 等待用戶從鍵盤輸入文件內(nèi)容,并將用戶的本次輸入內(nèi)容保存到一臨時變量text[]中,要求每次輸入以回車結(jié)束,全部結(jié)束用CTR+Z鍵(或其他設(shè)定的鍵); ⑥ 調(diào)用do_write()函數(shù)將通過鍵盤鍵入的內(nèi)容寫到文件中。 ⑦ 如果do_write()函數(shù)的返回值為非負值,則將實際寫入字節(jié)數(shù)增加do_write()函數(shù)返回值,否則顯示出錯信息,并轉(zhuǎn)⑨; ⑧ 如果text[]中最后一個字符不是結(jié)束字符CTR+Z,則轉(zhuǎn)⑦繼續(xù)進行寫操作;否則轉(zhuǎn)⑨; ⑨ 如果當(dāng)前讀寫指針位置大于用戶打開文件表項中的文件長度,則修改打開文件表項中的文件長度信息,并將fcbstate置1; ⑩ 返回實際寫入的字節(jié)數(shù)。 13.實際寫文件函數(shù)do_write() (1)對應(yīng)命令:無 (2)命令調(diào)用格式:無 (3)函數(shù)設(shè)計格式:int my_write(int fd,char *text,int len,char wstyle) (4)功能:被寫文件函數(shù)my_write()調(diào)用,用來將鍵盤輸入的內(nèi)容寫到相應(yīng)的文件中去。 (5)輸入: fd: open()函數(shù)的返回值,文件的描述符; text:指向要寫入的內(nèi)容的指針; len:本次要求寫入字節(jié)數(shù) wstyle:寫方式 (6)輸出:實際寫入的字節(jié)數(shù)。 (7)函數(shù)需完成的工作: ① 用malloc()申請1024B的內(nèi)存空間作為讀寫磁盤的緩沖區(qū)buf,申請失敗則返回-1,并顯示出錯信息; ② 將讀寫指針轉(zhuǎn)化為邏輯塊塊號和塊內(nèi)偏移off,并利用打開文件表表項中的首塊號及FAT表的相關(guān)內(nèi)容將邏輯塊塊號轉(zhuǎn)換成對應(yīng)的磁盤塊塊號blkno;如果找不到對應(yīng)的磁盤塊,則需要檢索FAT為該邏輯塊分配一新的磁盤塊,并將對應(yīng)的磁盤塊塊號blkno登記到FAT中,若分配失敗,則返回-1,并顯示出錯信息; ③ 如果是覆蓋寫,或者如果當(dāng)前讀寫指針?biāo)鶎?yīng)的塊內(nèi)偏移off不等于0,則將塊號為blkno的虛擬磁盤塊全部1024B的內(nèi)容讀到緩沖區(qū)buf中;否則便用ASCII碼0清空buf; ④ 將text中未寫入的內(nèi)容暫存到緩沖區(qū)buff的第off字節(jié)開始的位置,直到緩沖區(qū)滿,或者接收到結(jié)束字符CTR+Z為止;將本次寫入字節(jié)數(shù)記錄到tmplen中; ⑤ 將buf中1024B的內(nèi)容寫入到塊號為blkno的虛擬磁盤塊中; ⑥將當(dāng)前讀寫指針修改為原來的值加上tmplen;并將本次實際寫入的字節(jié)數(shù)增加tmplen; ⑦ 如果tmplen小于len,則轉(zhuǎn)②繼續(xù)寫入;否則轉(zhuǎn)⑧; ⑧ 返回本次實際寫入的字節(jié)數(shù)。 14.讀文件函數(shù)my_read() (1)對應(yīng)命令:my_read (2)命令調(diào)用格式:my_read fd len (3)函數(shù)設(shè)計格式:int myread (int fd, int len) (4)功能:讀出指定文件中從讀寫指針開始的長度為len的內(nèi)容到用戶空間中。 (5)輸入: fd: open()函數(shù)的返回值,文件的描述符; len: 要從文件中讀出的字節(jié)數(shù)。 (6)輸出:實際讀出的字節(jié)數(shù)。 (7)函數(shù)需完成的工作: ① 定義一個字符型數(shù)組text[len],用來接收用戶從文件中讀出的文件內(nèi)容; ② 檢查fd的有效性(fd不能超出用戶打開文件表所在數(shù)組的最大下標(biāo)),如果無效則返回-1,并顯示出錯信息; ③ 調(diào)用do_read()將指定文件中的len字節(jié)內(nèi)容讀出到text[]中; ④ 如果do_read()的返回值為負,則顯示出錯信息;否則將text[]中的內(nèi)容顯示到屏幕上; ⑤ 返回。 15.實際讀文件函數(shù)do_read() (1)對應(yīng)命令:無 (2)命令調(diào)用格式:無 (3)函數(shù)設(shè)計格式:int do_read (int fd, int len,char *text) (4)功能:被my_read()調(diào)用,讀出指定文件中從讀寫指針開始的長度為len的內(nèi)容到用戶空間的text中。 (5)輸入: fd: open()函數(shù)的返回值,文件的描述符; len: 要求從文件中讀出的字節(jié)數(shù)。 text:指向存放讀出數(shù)據(jù)的用戶區(qū)地址 (6)輸出:實際讀出的字節(jié)數(shù)。 (7)函數(shù)需完成的工作: ① 使用malloc()申請1024B空間作為緩沖區(qū)buf,申請失敗則返回-1,并顯示出錯信息; ② 將讀寫指針轉(zhuǎn)化為邏輯塊塊號及塊內(nèi)偏移量off,利用打開文件表表項中的首塊號查找FAT表,找到該邏輯塊所在的磁盤塊塊號;將該磁盤塊塊號轉(zhuǎn)化為虛擬磁盤上的內(nèi)存位置; ③ 將該內(nèi)存位置開始的1024B(一個磁盤塊)內(nèi)容讀入buf中; ④ 比較buf中從偏移量off開始的剩余字節(jié)數(shù)是否大于等于應(yīng)讀寫的字節(jié)數(shù)len,如果是,則將從off開始的buf中的len長度的內(nèi)容讀入到text[]中;否則,將從off開始的buf中的剩余內(nèi)容讀入到text[]中; ⑤ 將讀寫指針增加④中已讀字節(jié)數(shù),將應(yīng)讀寫的字節(jié)數(shù)len減去④中已讀字節(jié)數(shù),若len大于0,則轉(zhuǎn)②;否則轉(zhuǎn)⑥; ⑥ 使用free()釋放①中申請的buf。 ⑦ 返回實際讀出的字節(jié)數(shù)。 16. 退出文件系統(tǒng)函數(shù)my_exitsys() (1)對應(yīng)命令:my_exitsys (2)命令調(diào)用格式:my_ exitsys (1)函數(shù)設(shè)計格式:void my_exitsys() (2)功能:退出文件系統(tǒng)。 (3)輸入:無 (4)輸出:無。 (5)函數(shù)需完成的工作: ① 使用C庫函數(shù)fopen()打開磁盤上的myfsys文件; ② 將虛擬磁盤空間中的所有內(nèi)容保存到磁盤上的myfsys文件中; ③ 使用c語言的庫函數(shù)fclose()關(guān)閉myfsys文件; ④ 撤銷用戶打開文件表,釋放其內(nèi)存空間 ⑤ 釋放虛擬磁盤空間。 程序啟動 流程圖 文件系統(tǒng)是否存在 加載文件系統(tǒng) 是 否 創(chuàng)建文件系統(tǒng),并格式化 等待用戶命令輸入 用戶輸入命令 my_exitsys my_open my_rm my_create my_ls …… 3、 程序?qū)崿F(xiàn)代碼: #include- 1.請仔細閱讀文檔,確保文檔完整性,對于不預(yù)覽、不比對內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請點此認領(lǐng)!既往收益都歸您。
下載文檔到電腦,查找使用更方便
9.9 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標(biāo),表示該PPT已包含配套word講稿。雙擊word圖標(biāo)可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計者僅對作品中獨創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 操作系統(tǒng) 課程設(shè)計 簡單 文件系統(tǒng) 實現(xiàn)
鏈接地址:http://m.wymoca.com/p-6693566.html