- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
122windows操作系统原理ppt
缓冲与缓存 块型设备缓冲 用于磁盘、磁带等设备的I/O传输 每个缓冲区的长度与块型物理设备中一个块的长度相同, 即为512字节 缓冲区为所有块型设备公用, 其总数为15个 块型设备缓冲 struct buf { int b_flags; /* see definition below */ struct buf *b_forw; /* headed by devtab of b_dev */ struct buf *b_back; /* 设备b链向后指针 */ struct buf *av_forw; /* av链向前指针 */ struct buf *av_back; /* av链向后指针 */ int b_dev; /* 设备名 */ int b_wcount; /* 传送字数 */ char *b_addr; /* 内存地址(低位) */ char *b_xmem; /* 内存地址(高位) */ char *b_blkno; /* 设备物理块号 */ char b_error; /* 返回出错信息 */ char *b_resid; /* 传送剩余字节 */ }buf[NBUF]; 块型设备控制结构 struct devtab { char d_active; /* busy flag */ char d_erncnt; /* error count */ struct buf *b_forw; /* first buffer for this dev */ struct buf *b_back; /* last buffer for this dev */ struct buf *d_actf; /* head of IO queue */ struct buf *d_actl; /* tail of IO queue */ } 块缓冲数据读写 字符型设备缓冲 缓冲池 struct cblock { struct cblock *c_next; /* pointer */ char info[6]; /* info container */ } 读操作 写操作 预先读与延迟写 预先读(read ahead) 将以后即将使用的块读入缓冲区中 以后进程需要该块时便可在缓冲区中直接得到, 不必等待设备I/O传输 基于文件顺序访问的假设 延迟写(delayed write) 将当一个缓冲块尚未写满时, 暂不将其写到外存 以后继续写时, 不必将该块由外存读入内存 12.7.1 有关进程的系统调用命令 相关系统调用 创建子进程 Pid = fork() 加载并执行新程序 execl(prog, arg0,…argn-1,0) 进程自我结束 exit(status) 等待子进程终止 pid=wait(status) vfork 与 fork fork 功能 复制地址空间(code+data+stack) 复制控制结构(proc,user) 特点 父子进程之间有两个各自独立的数据拷贝 问题 不加载新程序 不能实现数据共享,不能描述诸如“有界缓冲区”问题 若加载新程序 复制没有意义,浪费时间和空间 vfork与fork vfork 只复制控制结构(proc+user); 不复制地址空间(code+data) 父子进程共享地址空间 使用 父进程使用 vfork 创建子进程; 子进程与父进程共享地址空间; 子进程使用 execve 改变其虚拟地址空间. 12.7.2有关文件的系统调用命令 创建文件 fd=creat(path_name,mode) 分配一个inode 填写目录项 以写方式打开该文件 返回文件描述符 打开文件 fd=open(path_name,mode) 查目录找到inode 权限检查 在file表中分配一个表项,指向该内存inode 在u_ofile中取一表目,指向file表中对应表目 返回文件描述符fd 有关文件的系统调用命令 关闭文件 close(fd) 由fd查u_ofile找到对应入口 由u_ofile[fd]找到file表对应入口 f_count-- i_count -- u_ofile[fd]=-1(空闲标志) 有关文件的系统调用命令 读命令 n_rd=read(fd,buf,ytes) 由u_ofile[fd],找到file表对应入口 检查访问权限(f_flag, READ) 由f_inode找到内存inode入口 由f_
您可能关注的文档
最近下载
- 妇科手术切口脂肪液化管理中国专家意见(2025年版)解读PPT课件.pptx VIP
- 卫生部修订病历书写基本规范(全文).pdf VIP
- 学术论文写作与规范课件(1).pptx VIP
- 2025年济南市中考英语试题卷(含答案解析).docx
- 【《社交媒体对旅游目的地营销传播的影响实证研究》20000字(论文)】 .pdf VIP
- 【安全类】卸料平台监理实施细则.docx VIP
- 标准图集-08SS523-建筑小区塑料排水检查井.pdf VIP
- 富士达各功能电梯地址码(1)(1).pdf VIP
- 建筑地面工程防滑技术规程.docx VIP
- 乡村振兴及人居环境整治工程施工图设计总说明.docx VIP
文档评论(0)