spooling技术和通道及实现打印机共享

spooling技术的作用: 
1、spooling技术的引入是为了 缓和高速CPU和低速I/O设备之间的矛盾 ; 
2、spooling技术能够允许多台外部设备进行联机并发操作, 实现虚拟性 ; 

在这个技术中用到了缓冲区和通道,缓冲区大家都比较熟悉,这里就不做介绍了,这里就简单的介绍一下通道。 


通道: 
1、通道技术的引入使得 CPU与外设并行操作成为可能;  
2、通道可看做专门的I/O处理机,它可以实现外设和主存直接交换数据; 
3、CPU和通道的关系: 
(1)在采用通道方式的指令系统中,有供通道专用的一组通道指令。当要进行I/O操作时,CPU只需启动通道,然后可以继续执行自身程序,通道则执行通道程序,管理与实现I/O操作; 

(2)整个系统分为二级管理,一级是CPU对通道的管理,二级是通道对设备控制的管理; 

Spooling系统和通道:


spooling实现打印机共享: 

spooling技术实现打印机共享的步骤如下图所示:

注:这里的spo是指输出进程。


打印机实际打印的步骤实现流程图:

  • 14
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SPOOLING技术 一、实验目的 理解和掌握SPOOLING技术。 二、实验内容 编写程序实现SPOOLING技术的模拟。 三、实验要求 1、设计一个实现SPOOLING技术进程 设计一个SPOOLING输出进程和两个请求输出的用户进程及一个SPOOLING输出服务程序。 SPOOLING输出进程工作时,根据请求块记录的各进程要输出的信息,将其实际输出到打印机或显示器。这里,SPOOLING进程与请求输出的用户进程可并发运行。 2、设计进程调度算法 进程调度采用随机算法,这与进程输出信息的随机性相一致。两个请求输出的用户进程的调度概率各为45%,SPOOLING输出进程为10%,这由随机数发生器产生的随机数模拟决定。 3、进程状态 进程基本状态有3种,分别为可执行、等待和结束。可执行状态就是进程正在运行或等待调度的状态;等待状态又分为等待状态1、等待状态2、等待状态3。 状态变化的条件为: (1)进程执行完成时,置为“结束”状态。 (2)服务程序在将输出信息送至输出井时,如发现输出井已满,将调用进程置为“等待状态1”。 (3)SPOOLING进程在进行输出时,若输出井空,则进入“等待状态2”。 (4)SPOOLING进程输出一个信息块后,应立即释放该信息块所占的输出井空间,并将正在等待输出的进程置为“可执行状态”。 (5)服务程序在输出信息到输出井并形成输出请求信息块后,若SPOOLING进程处于等待状态则将其置为“可执行状态”。 (6)当用户进程申请请求输出块时,若没有可用请求块时,调用进程进入“等待状态3”。 4、数据结构 1)进程控制块PCB struct pcb { int status; int length; }pcb[3]; 其中status表示进程状态,其取值: 0 表示可执行状态; 1 表示等待状态1; 2 表示等待状态2; 3 表示等待状态3 2)请求输出块reqblock struct{ int reqname;//请求进程名 int length;// 本次输出信息长度 int addr;// 信息在输出井的首地址 }reqblock[10]; 3)输出井BUFFER SPOOLING系统为每个请求输出的进程在输出井中分别开辟一个区。本实验可设计一个二维数组(int buffer[2][10])作为输出井。每个进程在输出井最多可占用10个位置。 5、编程说明 为两个请求输出的用户进程设计两个输出井。每个可存放10个信息,即buffer[2][10]。当用户进程将其所有文件输出完时,终止运行。 为简单起见,用户进程简单的设计成:每运行一次,随机输出数字0~9之间的一个数,当输入10个数时形成一个请求信息块,填入请求输出信息块reqblock结构中。
spooling技术是一种用于优化计算机系统资源利用技术,用来解决多个用户同时访问共享资源时的冲突和效率问题。而例程库则是一组提供给程序员使用的预定义例程或函数的集合。 在使用spooling技术时,系统会将用户的任务临时存储到磁盘或内存中,然后逐个处理,从而实现并发处理多个任务的目的。这样一来,多个用户就可以同时提交任务而不会产生冲突,也不需要等待其他任务的完成。 例程库是一个由各种常用函数和程序组成的库,可以为程序员提供快速、高效的开发工具。这些例程库中包含了各种常用的功能函数,例如输入输出操作、字符串处理、数学运算等。程序员可以通过调用这些例程来完成特定的任务,而不需要从头开始编写整个程序,大大提高了开发效率和代码质量。 结合spooling技术和例程库的优势,可以实现更高效的任务处理。多个用户可以同时提交任务,并且可以利用例程库中提供的函数来完成特定的任务,减少了代码开发的重复劳动。同时,通过spooling技术,可以更加充分地利用计算机系统的资源,提高系统的性能和效率。 总之,spooling技术和例程库的结合可以为计算机系统的任务处理提供更高效、更快速的解决方案,提高了系统的并发性和资源利用率。这对于用户和程序员来说都是非常有益的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值