77范文网 - 专业文章范例文档资料分享平台

模拟unix文件系统代码(3)

来源:网络收集 时间:2019-02-15 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

}

}

}

}

return false;

//recycle(inode[i]->file_address); //回事i节点占用的盘块 for (int i=0;i

inode[k]->file_address[i]=-1; }////////////////////////////// inode[k]->file_length=-1; inode[k]->file_style=-1; superblock.i_node_num[k]=0;

direct[i]->i_num =-1; ///这一段是恢复当前目录项和磁盘i 节点到初始状态 direct[i]->file_name=\;

direct[i]->p_id=-1;///////////////////////////// return true;

cout<<\目录不存在或者其不是目录文件或者其是当前目录!!!!!!!!\<

////////////////////////////////////////////////////////////////////////// //打开文件

int open_file(string filename,int cur_dir_id,int cur_user_id,int mod=0) {

}

fclose(fp);

for (int i=0;i<5;i++) {

fread(&users[i],sizeof(class user),1,fp); user users[5]; int k; FILE *fp;

fp=fopen(\,\);

for (int i=0;i

if

k =direct[i]->i_num;// 磁盘i节点号

(filename==direct[i]->file_name&&inode[k]->file_style==1&&direct[i]->p_id==cur_dir_id)//查找filename 的目录项//判断i节点是不是文件项 //判断找到的目录项是不是当前目录下的文件;

{

if (users[cur_user_id].user_mod-inode[k]->i_mod >=mod) {

bool flag=false;

int curent,sys_curent,fd; for( int j=0;j

if (!flag) {

if (act_inode_list[i]!=NULL&&act_inode_list[j]->i_num==k) { }

act_inode_list[j]->Associated_number++;

inode[k]->Associated_number++; //修改i节点文件关联数目; flag =true;curent = j; j=LIST;

for (int i=0;i

}

for (int j=0;j

if (act_inode_list[i]==NULL) {

act_inode_list[i]= new active_inode;

act_inode_list[i]->Associated_number++;inode[k]->Associated_number++;

act_inode_list[i]->file_address[j]=inode[k]->file_address[j];

act_inode_list[i]->file_length=inode[k]->file_length;

for (int m=0;m

}

}

}

act_inode_list[i]->i_num=k;

act_inode_list[i]->i_mod=inode[k]->i_mod; curent =i; i=LIST;

act_inode_list[i]->file_style=inode[k]->file_style;

}

{ }

{ }

if (sys_list[m]==-1) { }

sys_list[m]=curent;// 给系统打开表添sys_curent =m; m =LIST;

加一项

if (user_list[cur_user_id]==NULL)

user_list[cur_user_id] = new int[LIST]; for (int j=0;j

user_list[cur_user_id][j]=-1; }

user_list[cur_user_id][0]=sys_curent; fd=0;

user_list[cur_user_id][LIST]=1;

else

for (int i=0;i

if (user_list[cur_user_id][i]==-1) { } }

user_list[cur_user_id][i]=sys_curent;

user_list[cur_user_id][LIST]=user_list[cur_user_id][LIST]+1; i=LIST; fd =i;

return fd; }

} else { }

cout<<\打开失败:权限不够\<

cout<<\打开失败:可能文件不存在或者文件不在当前目录下\<

}

//////////////////////////////////////////////////////////////////////////////////// //写文件

bool write_file(int fd ,int cur_user_id,string file) {

int block_num,inode_num,sys,k; int *add;

if (file.length()d == 0)

block_num=(int)file.length()/64; else

block_num=(int)file.length()/64+1; add=allocat(block_num);

sys=user_list[cur_user_id][fd];

return true; }

inode_num= sys_list[sys];

for (int i=0;i

act_inode_list[inode_num]->file_length=file.length(); k =act_inode_list[inode_num]->i_num; for (int i=0;i

inode[k]->file_address[i]=add[i]; }

inode[k]->file_length=file.length(); int num,index; num=64; index=0;

for (int i=0;i

if (i==block_num-1) {

num=file.length()d; }

file.copy(memory[add[i]]->data,num,index); //将字符串加到每个块中; index+=num;

act_inode_list[inode_num]->file_address[i]=add[i];

//读文件

string read_file(int fd,int cur_user_id) {

int sys,inode_num,k,length,block_num; int * add; string file; }

//关闭文件

bool close_file(int fd,int cur_user_id) {

int sys,inode_num;

for (int i=0;i< user_list[cur_user_id][LIST];i++) {

if (fd == user_list[cur_user_id][i]) {

inode_num=sys_list[fd]; user_list[cur_user_id][i]=-1; sys_list[fd]=-1;

act_inode_list[inode_num]->Associated_number--; if (act_inode_list[inode_num]->Associated_number==0) {

delete act_inode_list[inode_num]; act_inode_list[inode_num]=NULL; sys=user_list[cur_user_id][fd]; inode_num= sys_list[sys];

k=act_inode_list[inode_num]->i_num; length=inode[k]->file_length; add=inode[k]->file_address; if (lengthd==0)

block_num=(int)file.length()/64; else

block_num=(int)length/64+1; int num =64;

for (int i=0;i

return file;

if (i==block_num-1) { }

file.append(memory[add[i]]->data,num);

num=lengthd;

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库模拟unix文件系统代码(3)在线全文阅读。

模拟unix文件系统代码(3).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/zonghe/473958.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: