亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? filesystem.cpp

?? LINUX 設計一個簡單的二級文件系統
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include <iostream.h>
#include <stdio.h>
#include <string.h>
#include "FileSystem.h"
#include "string2"
#include "Util.h"

SuperBlock sb;
FILE* fd;
hinode hinode[NHINO];
SysOFile sys_ofile[100];

unsigned long FileSystem::mapAddr(unsigned int id) {
	unsigned long addr;
	addr = this->IN_Start+sizeof(DInode)*(id-1);
	return addr;
}
void FileSystem::SaveSuperBlock() {
	fseek(fd, 0, 0);
	fwrite(&sb, 1, sizeof(SuperBlock), fd);
}
FileSystem::~FileSystem() {}
FileSystem::FileSystem() {
	strcpy(this->Disk_Name, "FileSystem.disk");
	this->LoginNum = 0;
	this->IN_Start = BlockSize * 2;
	this->Data_Start = BlockSize * (2 + 400);
	this->GroupSize = 50;
}

void FileSystem::ShowList(const char* usn) {
	if (!this->CheckLogin(usn)) return;
	unsigned int curDir = this->LoginUser[this->UNameI(usn)].CurDirInodeID;
	INode* inode = this->IGet(curDir);
	Direct dir;
	fseek(fd, inode->addr[0]*BlockSize, 0);
	fread(&dir, 1, sizeof(Direct), fd);
	this->IPut(inode);
	int i = 0;
	if (curDir != this->LoginUser[this->UNameI(usn)].user.Dino) {
		i = 1;
		cout << "文件總數: " << dir.size-1 << endl;
	} else {
		cout << "文件總數: " << dir.size << endl;
	}

	for (; i<dir.size; i++) {
		cout << "名稱:" << dir.files[i].name << '\t';
		inode = this->IGet(dir.files[i].Dino);
		if (inode->size == 0)
			cout << "物理地址:" << this->mapAddr(inode->Dino) << "\t大小:" << "1 KB";
		else
			cout << "物理地址:" << inode->addr[0]*BlockSize << "\t大?。?quot; << inode->size << " KB";
		cout << "\t保護碼:" << inode->type;
		int di_mode, one;
		for (int j=0; j<4; j++) {
			di_mode = inode->mode;
			one = di_mode % 2;
			di_mode = di_mode / 2;
			if (one) cout << 'x';
			else cout << '*';
		}
		cout << endl;
	}
}

void FileSystem::MakeDir(const char *usn, const char *name) {
	if (!this->CheckLogin(usn)) return;
	if (!u.regTest("^[a-zA-Z0-9._]{1,16}$", name)) {
		cout << "目錄名稱只能是1至16位字母或數字或點號下劃線組成!" << endl;
		return;
	}
	unsigned int dinodeid = this->NameI(usn, name);
	if (dinodeid != 0) {
		cout << "相同名稱的文件或目錄已經存在!" << endl;
		return;
	}
	Direct dir;
	dir.size = 1;
	strcpy(dir.files[0].name, "..");
	dir.files[0].Dino = this->LoginUser[this->UNameI(usn)].CurDirInodeID;
	unsigned int Bid = this->BAlloc();
	if (Bid == 0) {
		return;
	}
	INode* inode = this->IAlloc();
	if (inode == NULL) {
		this->BFree(Bid);
		return;
	}
	fseek(fd, Bid*BlockSize, 0);
	fwrite(&dir, 1, sizeof(Direct), fd);
	inode->size = 1;
	inode->addr[0] = Bid;
	inode->type = 'd';
	inode->mode = '0';
	Bid = inode->Dino;
	this->IPut(inode);
	File file;
	strcpy(file.name, name);
	file.Dino = Bid;
	unsigned int curDir = this->LoginUser[this->UNameI(usn)].CurDirInodeID;
	INode* inode2 = this->IGet(curDir);
	fseek(fd, inode2->addr[0]*BlockSize, 0);
	fread(&dir, 1, sizeof(Direct), fd);
	dir.files[dir.size] = file;
	dir.size++;
	fseek(fd, inode2->addr[0]*BlockSize, 0);
	fwrite(&dir, 1, sizeof(Direct), fd);
	this->IPut(inode2);

	cout << "目錄創建成功!" << endl;
}

// 創建文件
void FileSystem::MakeFile(const char *usn, const char *filename) {
	if (!this->CheckLogin(usn)) return; // 用戶登錄檢測
	if (!u.regTest("^[a-zA-Z0-9._]{1,16}$", filename)) { // 文件名合法性檢測
		cout << "文件名稱只能是1至16位字母或數字或點號下劃線組成!" << endl;
		return;
	}
	// 調用 NameI 方法通過名稱找到索引節點編號
	unsigned int dinodeid = this->NameI(usn, filename);
	if (dinodeid != 0) {
		cout << "相同名稱的文件或目錄已經存在!" << endl;
		return;
	}
	// 分配 索引節點
	INode* inode = this->IAlloc();
	if (inode == NULL) return;
	// 填入初始化信息
	inode->size = 0;
	inode->type = 'f';
	inode->mode = '1';
	// 初始化文件
	File file;
	strcpy(file.name, filename);
	file.Dino = inode->Dino;
	this->IPut(inode);
	// 將新文件插入目錄表中
	unsigned int curDir = this->LoginUser[this->UNameI(usn)].CurDirInodeID;
	INode* inode2 = this->IGet(curDir);
	Direct dir;
	fseek(fd, inode2->addr[0]*BlockSize, 0);
	fread(&dir, 1, sizeof(Direct), fd);
	dir.files[dir.size] = file;
	dir.size++;
	fseek(fd, inode2->addr[0]*BlockSize, 0);
	fwrite(&dir, 1, sizeof(Direct), fd);
	this->IPut(inode2);
	cout << "文件創建成功!" << endl;
}


void FileSystem::IFree(unsigned int dinodeid) {
	unsigned int id;
	unsigned long addr;
	DInode dino;
	if (sb.pFI == 100) { // 棧滿
		for (int i=0; i<50; i++) { // 取一半存盤
			id = sb.FIS[sb.pFI-1];
			addr = this->mapAddr(id);
			fseek(fd, addr, 0);
			fread(&dino, 1, sizeof(DInode), fd);
			dino.type = 's';
			fwrite(&dino, 1, sizeof(DInode), fd);
		}
	}
	sb.FIS[sb.pFI] = dinodeid;
	sb.FINum++;
	sb.pFI++;
}

INode* FileSystem::IAlloc() {
	INode* temp_inode;
	int i, count;
	unsigned long addr;
	if (sb.FINum == 0) {
		cout << "無法再分配更多的 I 結點!" << endl;
		return NULL;
	}
	if (sb.pFI == 0) { // ??? 補棧
		i = 0;
		count = 0;
		DInode in;
		for (i=0; i<IBlockNum*BlockSize/sizeof(DInode); i++) {
			addr = this->mapAddr(i);
			fseek(fd, addr, 0);
			fread(&in, 1, sizeof(DInode), fd);
			if (in.type == 'e') {
				sb.FIS[sb.pFI] = in.no;
				in.type = 's';
				fseek(fd, addr, 0);
				fwrite(&in, 1, sizeof(DInode), fd);
				sb.pFI++;
				count++;
				if (count == 50) {
					break;
				}
			}
		}
	}
	unsigned int id = sb.FIS[sb.pFI-1];
	temp_inode = this->IGet(id);
	//temp_inode->type = 's';
	addr = this->mapAddr(id);
	fseek(fd, addr, 0);
	fwrite(&temp_inode->di_number, 1, sizeof(DInode), fd);
	sb.pFI--;
	sb.FINum--;
	sb.SysMod = 0;
	this->SaveSuperBlock();
	return temp_inode;
}


INode* FileSystem::IGet(unsigned int dinodeid) {
	int inodeid = dinodeid % NHINO;
	int existed = 0;
	long addr;
	INode *temp, *newinode;

	if (hinode[inodeid].iForw != NULL) {
		// 如果 HASH 表中該 HASH 隊列不為空, 查找節點
		temp = hinode[inodeid].iForw;
		while (temp) {
			if (temp->i_ino == inodeid) {
				// 如果找到該索引節點
				existed = 1;
				temp->Icount++;
				return temp;
			} else {
				temp = temp->iForw;
			}
		}
	}
	// HASH 表中不存在該節點, 則計算對應磁盤 I節點 地址
	addr = this->mapAddr(dinodeid);

	// 分配內存, 并從磁盤載入信息
	newinode = (INode*)malloc(sizeof(INode));
	fseek(fd, addr, 0);
	fread(&newinode->di_number, 1, sizeof(DInode), fd);

	// 將該節點置入 HASH 表中
	newinode->iForw = hinode[inodeid].iForw;
	newinode->iBack = newinode;
	if (newinode->iForw != NULL) {
		newinode->iForw->iBack = newinode;
	}
	hinode[inodeid].iForw = newinode;
	
	// 填好初始化信息
	newinode->Icount = 1;
	newinode->flag = 0;				// 標記是否被更新
	newinode->i_ino = inodeid;


	// newinode->di_size=3*(DIRSIZ+2);
	// if(dinodeid == 3) newinode->di_size=BLOCKSIZ;
	return newinode;
}

void FileSystem::IPut(INode* pinode) {
	unsigned long addr;
	addr = this->mapAddr(pinode->Dino);
	fseek(fd, addr, 0);
	fwrite(&pinode->di_number, 1, sizeof(DInode), fd);
	if (pinode->Icount > 1) {
		pinode->Icount--;
		return;
	}

	if (pinode->iForw == NULL) {
		pinode->iBack->iForw = NULL;
	} else {
		pinode->iForw->iBack = pinode->iBack;
		pinode->iBack->iForw = pinode->iForw;
	}
	/*
	if (pinode->di_number != 0) {
		addr = this->mapAddr(pinode->Dino);
		fseek(fd, addr, 0);
		fwrite(&pinode->di_number, 1, sizeof(DInode), fd);
	} else {
		for (int i=0; i<pinode->size; i++) {
			this->BFree(pinode->addr[i]);
		}
		//this->IFree(pinode->Dino);
	}
	if (pinode->iForw == NULL) {
		pinode->iBack->iForw = NULL;
	} else {
		pinode->iForw->iBack = pinode->iBack;
		pinode->iBack->iForw = pinode->iForw;
	}
	this->IFree(pinode->Dino);*/
}

unsigned int FileSystem::NameI(const char *usn, const char *name) {
	if (0==strcmp("/", name)) {
		return this->LoginUser[this->UNameI(usn)].user.Dino;
	} else if (0==strcmp(".", name)) {
		return this->LoginUser[this->UNameI(usn)].CurDirInodeID;
	} else {
		unsigned int curDir = this->LoginUser[this->UNameI(usn)].CurDirInodeID;
		INode* inode = this->IGet(curDir);
		Direct dir;
		fseek(fd, inode->addr[0] * BlockSize, 0);
		fread(&dir, 1, sizeof(Direct), fd);
		this->IPut(inode);
		for (int i=0; i<dir.size; i++) {
			if (strcmp(dir.files[i].name, name)==0) {
				return dir.files[i].Dino;
			}
		}
		return 0;
	}
}

void FileSystem::ChangeDir(const char *usn, const char *name) {
	if (!this->CheckLogin(usn)) return;
	int dinodeid = this->NameI(usn, name);
	if (dinodeid==0) {
		cout << "目錄不存在!" << endl;
		return;
	}
	INode* inode = this->IGet(dinodeid);
	if (inode == NULL) {
		cout << "目錄不存在!" << endl;
		return;
	}
	if (inode->type != 'd') {
		cout << "目錄不存在!" << endl;
		return;
	}
	// cout << "當前目錄:" << name << endl;
	int uid = this->UNameI(usn);
	this->LoginUser[uid].CurDirInodeID = dinodeid;
}

bool FileSystem::Login(const char *usn, const char *pwd) {
	if (this->LoginNum > 3) {
		cout << "當前系統太多人登錄,請稍后登錄!" << endl;
		return 0;
	}
	int i;
	for (i=0; i<this->LoginNum; i++) {
		if (strcmp(usn, this->LoginUser[i].user.usn)==0) {
			cout << "您已經登陸,不用重復登錄!" << endl;
			return 0;
		}
	}
	for (i=0; i<4; i++) {
		if (strcmp(this->AllUser[i].usn, usn)==0 && strcmp(this->AllUser[i].pwd, pwd)==0) {
			cout << "登錄成功!" << endl;
			this->LoginUser[this->LoginNum].user = this->AllUser[i];
			this->LoginNum++;
			LoginUser[this->LoginNum].CurDirInodeID = this->AllUser[i].Dino;
			this->ChangeDir(usn, "/");
			return 1;
		}
	}
	cout << "你輸入的用戶名或者密碼不正確!" << endl;
	return 0;
}

void FileSystem::Logout(const char *usn) {
	if (!this->CheckLogin(usn)) return;
	int j, k;
	for (int i=0; i<this->LoginNum; i++) {
		if (strcmp(this->LoginUser[i].user.usn, usn)==0) {
			int uid = this->UNameI(usn);
			for (k=0; k<100; k++) {
				if (sys_ofile[k].f_count > 0 && sys_ofile[k].uid == uid) {
					this->Close(usn, k);
				}
			}
			for (j=i; j<3; j++) {
				this->LoginUser[j] = this->LoginUser[j+1];
			}
			this->LoginNum--;
			cout << "登出成功!" << endl;
			return;
		}
	}
}

int FileSystem::CheckLogin(const char *usn) {
	for (int i=0; i<this->LoginNum; i++) {
		if (strcmp(this->LoginUser[i].user.usn, usn)==0) {
			return 1;
		}
	}
	cout << "對不起,您還未登錄,請先登錄!" << endl;
	return 0;
}

void FileSystem::Load() {
	fd = fopen(this->Disk_Name, "r+w+b");
	if (fd == NULL) {
		cout << "文件系統無法加載!" << endl;
		exit(0);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合在线第一页| 久久综合九色综合久久久精品综合| 国产日韩视频一区二区三区| 久99久精品视频免费观看| 欧美电影免费观看高清完整版在| 免费成人在线播放| 日韩美一区二区三区| 久久国产婷婷国产香蕉| 久久久久久久久久美女| 成人h动漫精品一区二区| 亚洲欧美激情小说另类| 欧美蜜桃一区二区三区| 奇米一区二区三区| 日本一区二区三区在线不卡| 99这里只有久久精品视频| 一区二区三区不卡在线观看| 制服丝袜av成人在线看| 韩国理伦片一区二区三区在线播放| 国产三级一区二区三区| 97久久精品人人爽人人爽蜜臀| 一区二区成人在线| 日韩精品中文字幕一区| 成人毛片视频在线观看| 午夜精品免费在线观看| 精品国产百合女同互慰| 99久久99久久精品免费看蜜桃 | 久久精品国产99| 国产欧美日韩另类一区| 在线观看欧美日本| 精品在线观看免费| 亚洲精品自拍动漫在线| 精品人在线二区三区| 97精品电影院| 另类小说色综合网站| 中文字幕中文字幕在线一区| 欧美人妇做爰xxxⅹ性高电影| 国产精品888| 香蕉成人啪国产精品视频综合网| 国产亚洲欧美激情| 欧美日韩国产美| 不卡一二三区首页| 麻豆国产91在线播放| 亚洲日本乱码在线观看| 精品91自产拍在线观看一区| 在线免费观看日韩欧美| 国产精品99久久久久久似苏梦涵| 亚洲国产一区二区三区青草影视| 久久免费美女视频| 制服丝袜中文字幕亚洲| 91亚洲午夜精品久久久久久| 久久不见久久见免费视频1| 亚洲综合色在线| 中文字幕一区av| 国产色一区二区| 日韩精品在线网站| 91精品免费在线| 在线看国产日韩| 99精品视频一区| 国产成人亚洲综合a∨婷婷图片| 亚洲一区二区av在线| 亚洲日本在线a| 中文字幕免费一区| 日韩女同互慰一区二区| 欧美电影影音先锋| 欧美性欧美巨大黑白大战| 色婷婷国产精品综合在线观看| 国产精品香蕉一区二区三区| 激情都市一区二区| 麻豆成人91精品二区三区| 亚洲成人777| 夜夜揉揉日日人人青青一国产精品 | 亚洲第一激情av| 一区二区三区在线观看网站| 成人免费一区二区三区视频| 欧美国产丝袜视频| 国产欧美视频一区二区三区| 久久免费视频色| 国产视频一区在线播放| 国产农村妇女精品| 国产精品沙发午睡系列990531| 久久精品亚洲精品国产欧美 | 久久精品免视看| 亚洲精品在线三区| 久久精品亚洲乱码伦伦中文| 久久精品综合网| 国产亚洲欧美在线| 国产欧美久久久精品影院| 欧美经典一区二区| 国产精品久久午夜夜伦鲁鲁| 国产精品欧美极品| 亚洲啪啪综合av一区二区三区| 国产精品传媒在线| 综合久久给合久久狠狠狠97色| 亚洲日本成人在线观看| 一区二区三区在线观看视频 | 麻豆精品久久久| 韩国视频一区二区| 成人永久aaa| 91婷婷韩国欧美一区二区| 在线观看一区二区视频| 欧美亚洲国产一区二区三区va| 欧美午夜电影一区| 日韩美女视频在线| 国产农村妇女精品| 亚洲激情综合网| 亚洲成人av一区| 国产精品69毛片高清亚洲| 9久草视频在线视频精品| 欧美日韩精品一区二区在线播放| 欧美一级高清片| 中文字幕av一区二区三区免费看| 亚洲精品亚洲人成人网在线播放| 亚洲不卡av一区二区三区| 韩国欧美国产1区| 一本色道亚洲精品aⅴ| 91精品国产免费| 国产午夜精品一区二区三区嫩草 | 久久蜜臀中文字幕| 亚洲欧美经典视频| 卡一卡二国产精品| 91香蕉视频污| 精品国产网站在线观看| 亚洲欧洲在线观看av| 日韩国产在线一| 成人黄色一级视频| 69堂成人精品免费视频| 中文久久乱码一区二区| 五月婷婷综合激情| 99视频超级精品| 欧美成人艳星乳罩| 亚洲永久精品国产| 国产一区999| 欧美日韩国产成人在线91| 欧美国产欧美综合| 日本伊人色综合网| 91论坛在线播放| 久久久久久久综合狠狠综合| 日韩影院免费视频| 色播五月激情综合网| 欧美激情在线看| 狠狠色丁香婷综合久久| 4438成人网| 一区二区三区在线免费观看| 成人福利在线看| 久久久久久久久久久黄色 | 蜜桃视频在线观看一区| 91久久一区二区| 欧美国产一区二区在线观看| 久久av中文字幕片| 在线播放日韩导航| 亚洲综合色婷婷| 一本一道久久a久久精品| 国产嫩草影院久久久久| 国产在线一区观看| 欧美一级日韩不卡播放免费| 亚洲午夜精品一区二区三区他趣| 成人国产精品免费网站| 久久久国产精品午夜一区ai换脸| 美女视频黄久久| 9191精品国产综合久久久久久| 亚洲精品免费在线| 91亚洲精华国产精华精华液| 日本一区二区三区电影| 国产麻豆视频一区二区| 久久一区二区三区四区| 精品在线一区二区三区| 欧美哺乳videos| 日韩成人一级片| 日韩一级视频免费观看在线| 亚洲成年人影院| 欧美一级片在线观看| 日韩精品乱码免费| 日韩视频免费观看高清在线视频| 偷拍一区二区三区四区| 欧美精品在线一区二区三区| 亚洲成在人线免费| 日韩欧美国产三级| 久热成人在线视频| 久久九九久久九九| 国产91在线观看| 亚洲视频图片小说| 在线免费观看日本欧美| 丝瓜av网站精品一区二区| 91精品国产丝袜白色高跟鞋| 美女久久久精品| 久久婷婷成人综合色| 成人av午夜影院| 亚洲一二三区在线观看| 欧美日本在线观看| 久久草av在线| 国产精品久久网站| 欧美视频一区二| 韩日av一区二区| 自拍视频在线观看一区二区| 色94色欧美sute亚洲线路一久| 五月天丁香久久| 久久丝袜美腿综合| 91一区二区在线| 日本午夜精品一区二区三区电影| 久久蜜桃av一区精品变态类天堂|