Forth-83 多任务解析
body, table{font-family: 微软雅黑; font-size: 13.5pt}
table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;}
th{border: 1px solid gray; padding: 4px; background-color: #DDD;}
td{border: 1px solid gray; padding: 4px;}
tr:nth-child(2n){background-color: #f8f8f8;}
| 变量名 | 意义 |
| TOS | 指向参数堆栈顶 |
| ENTRY | 当任务被激活时转移的入口点 |
| LINK | 指向下一个任务 |
| SP0 | 参数堆栈的起始地址 |
| RP0 | 返回堆栈的起始地址 |
| DP | 词典的顶部 |
| #OUT | 已发送的字符数 |
| #LINE | 已打印的行数 |
| OFFSET | 当前文件的块位移 |
| BASE | 当前在输入/输出转换中采用的数制 |
| HLD (- addr) | 指向在 PAD 区中刚转换完的字符 |
| FILE | 指向当前文件的 FCB |
| IN-FILE | 指向输入文件的 FCB |
| PRINTING | 打印机状态标志,其值为真时,打印机处于激活状态 |
| 词 | 堆栈 | 功能 |
| (PAUSE) | ( - ) | 停止当前任务的执行,把控制转交给下一个任务。
它把 IP 及 RP 存放到参数堆栈上,把参数堆栈指针存进用户变量 TOS 中,转移到由 LINK 所指着的代码,从而实现多任务转换。 |
| RESTART | ( - ) | 与(PAUSE)相反。取回所存放的信息,执行在上一轮暂停的任务 |
| SLEEP | ( addr - ) | addr 是任一用户区的首地址,SLEEP 使该任务永远暂停 |
| WAKE | ( addr - ) | 唤醒一个在"睡觉"的任务,使它在下一次轮到时运行 |
| STOP | ( - ) | 永远暂停当前任务 |
| PAUSE | ( - ) | 在多任务环境中 PAUSE 执行 (PAUSE) |
| : STOP ( - ) UP @ 返回当前任务的地址 SLEEP 使当前任务“睡觉” PAUSE ; 立即停止当前任务而开始执行下一个任务 |
CODE PAUSE NEXT END-CODE 在单任务运行方式下,PAUSE 立即返回什么也不做;但在多任务方式中,把(PAUSE)的代码指针域的内容填入到 PAUSE 的代码指针域中,于是一个任务执行到 PAUSE 时就暂停下来。 |
| 词 | 堆栈 | 功能 |
| #USER | (- addr) | 存放在用户区大小的变量 |
| @LINK | (- addr) | 给出下一任务的ENTRY的地址 |
| !LINK | (addr -) | 把一相对距离赋给当前任务的 LINK。使之 LINK+(LINK) 等于下一任务用户区的首地址 |
| LOCAL | (base addr - addr1) | base为下一任务用户区的首地址,addr 为本任务之某一用户变量的地址,addr1是下一任务的同一用户变量的地址。 |
| SET-TASK | (ip addr -) | 使地址为addr的任务执行由ip指着的代码 |
| : TASK: ( size - ) 建立一个新任务和做有关的初始化工作(size -) // size 表示词典空间大小 CREATE 建立新任务的首部 TOS 当前任务用户区首址 HERE 新任务的用户区从此处开始 #USER @ 取出用户区的大小 (size 当前用户区首址 新任务用户区首址 用户区大小 - ) CMOVE 把现行任务的用户变量复制给新任务,初始化新任务的用户区 (size -) @LINK 新任务的 ENTRY 的地址 (size 新任务入口地址 -) UP @ -ROT 把当前任务的用户区指针送到堆栈低暂存 (当前用户区起始地址 size 新任务入口地址 -) HERE UP ! 使 UP 指向新任务的用户区 (当前用户区起始地址 size 新任务入口地址 -) !LINK 把现行任务用户区的地址存入到新任务的 LINK 中 (当前用户区起始地址 size -) DUP HERE + 新用户区及size之和的下一地址 (当前用户区起始地址 size 新用户区和size和的下一个地址 -) DUP RP0 ! 初始化新任务的返回堆栈指针 (当前用户区起始地址 size 新用户区和size和的下一个地址 -) 100 - SP0 ! 初始化新任务的参数堆栈指针 (当前用户区起始地址 size -) SWAP UP ! 恢复 UP 指向现行任务 (size -) HERE ENTRY LOCAL !LINK 把新任务的地址存进现行任务的 LINK 中 (size -) HERE #USER @ + 新任务词典区首地址 (size 新任务词典区首地址 -) HERE DP LOCAL ! 初始化新任务词典指针 (size -) HERE SLEEP 首先使新任务处于"睡眠"状态 (size -) ALLOT ; 分配 size 个字节给新任务 (-) |
| : BACKGROUND: ( - ) 建立一个词典空间为 400 个字节的新任务,初始化该任务去执行跟着的代码 400 TASK: 建立一个以跟着的名字命令的新任务 HERE IP 指向有待编译的代码,使得新任务可以执行它 (新任务地址 当前解释指针位置 - ) @LINK 2- 新任务的地址 (新任务地址 当前解释指针位置 新任务入口地址-2 -) SET-TASK 初始化新任务,让她执行 IP 指着的代码 (新任务地址 - ) !CSP 编译程序查错初始化 ] ; 调用编译程序,编译要为新任务执行的跟着的代码 |
多任务调度:
| 词 | 堆栈 | 功能 |
| MULTI | (-) | 建立多任务调度循环 |
| SINGLE | (-) | 取消多任务调度循环 |
| : SINGLE ( - ) ['] PAUSE >BODY ['] PAUSE ! ; |
定义中的第一行返回 PAUSE 的 pfa ,它指向 NEXT 。注意:PAUSE 是 CODE 定义,CODE 词的代码指针域内的内容是其参数域地址。定义第二行恢复 PAUSE 的代码指针域为常态。这样 PAUSE 就将立即返回而不再执行(PASE) |
F83 中是用词 BACKGROUND: 定义一个新任务,它把一个任务的首部定义为一个变量,因此引用一个任务的名字就在参数堆栈上留下该任务的参数域地址,而它就是一个任务的用户区的首地址。因此,键入一任务名 SLEEP 就把 JMP NOP 的代码存入该任务的 ENTRY 中,从而使任务处于“睡眠”状态。而键入一任务名 WAKE 就把 INT 80H 的代码存入任务的 ENYTRY 中,于是在下一轮中轮到时就投入运行。在一个任务的建立过程中,同时也把它加入到多任务链中,一个任务的用户变量 LINK 本身的地址与 LINK 单元的内容之和总是指向链中的下一个任务。用这种方法把一个前台作业和多个后台作业彼此间链接起来 。
Forth-83 多任务解析的更多相关文章
- iOS开发网络篇—XML数据的解析
iOS开发网络篇—XML数据的解析 iOS开发网络篇—XML介绍 一.XML简单介绍 XML:全称是Extensible Markup Language,译作“可扩展标记语言” 跟JSON一样,也是 ...
- fdisk -l解析
fdisk -l显示信息详解 [root@www.linuxidc.com ~]# fdisk -l Disk /dev/sda: 10.7 GB, 10737418240 bytes 255 hea ...
- RHEL7 CentOS7 检查查看精简指令
RHEL7 CentOS7 检查查看精简指令: //////////////////////////检查查看精简指令://///////////////////////////// ///////// ...
- Oracle 11g R2性能优化 tkprof
另一篇博文总结了关于SQL TRACE工具的使用方式,但是产生的trace文件格式阅读起来并不是十分友好,为了更好的分析trace文件,Oracle也自带了一个格式化工具tkprof.tkprof工具 ...
- functions 示例
示例1: ","字符串截取 CREATE OR REPLACE FUNCTION splitstr(p_string IN VARCHAR2, p_delimiter IN VA ...
- python多任务处理
多任务解析 什么叫“多任务”呢?简单地说,就是操作系统可以同时运行多个任务. 现在,多核CPU已经非常普及了,但是,即使过去的单核CPU,也可以执行 多任务.由于CPU执行代码都是顺序执行的,那么,单 ...
- C# 简易的串口监视上位机实现
实现上位机和下位机之间的通信,通常使用的是串口通信,接下来实现一个通过上位机和串口调试助手来完成串口通信测试. 首先创建一个WInfrom窗体应用工程文件,创建过程可参考https://www.cnb ...
- 设计模式课程 设计模式精讲 8-3 单例设计模式-DoubleCheck双重检查实战及原理解析
1 课程讲解 1.1 为何要使用双重检查 1.2 双重检查的缺点 1.3 指令重排序讲解 1.4 指令重排序比喻(自己理解) 1.5 如何解决指令重排序问题 2 代码演练 2.1 代码演练1(双重检查 ...
- 让DB2跑得更快——DB2内部解析与性能优化
让DB2跑得更快——DB2内部解析与性能优化 (DB2数据库领域的精彩强音,DB2技巧精髓的热心分享,资深数据库专家牛新庄.干毅民.成孜论.唐志刚联袂推荐!) 洪烨著 2013年10月出版 定价:7 ...
随机推荐
- 数据服务器------sql
服务器:能够在网站中提供各种(浏览网页,收发邮件视频,语言)等服务器的软件与硬件集合. 数据库服务器(软件):(特点:永久海量存储数据:高速的查询){所有其他软件没有的特点} 数据库服务器分类 网状数 ...
- Django Form表单组件
Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否 ...
- Java笔试
异常 Throwable是Java错误处理的父类,有两个子类:Error和Exception. Error:无法预期的严重错误,导致JVM虚拟机无法继续执行,几乎无法恢复捕捉的 Exception:可 ...
- 确定有穷自动机(DFA)的化简(最小化)
参考博客地址:https://blog.csdn.net/qq_33605778/article/details/80105658
- sed命令替换文件的内容【学习笔记】
sed -i "s/line/Line/g" `grep "line" -rl /home//zhuangzebin/`
- oracle 11g RAC 的基本操作(一)------启动与关闭
启动RAC 手工启动按照HAS, cluster, database的顺序启动,具体命令如下: 启动HAS(High Availability Services),必须以root用户 [root@or ...
- #!/usr/bin/python3 和 #!/usr/bin/env python3的区别
脚本语言的第一行指出用什么程序去执行代码. #!/usr/bin/python3调用/usr/bin下的python3解释器.#!/usr/bin/env python3首先会到env设置里查找pyt ...
- Apache Solr入门教程(转)
1.为什么选择Apache Solr Apache Solr是一个功能强大的搜索服务器,它支持REST风格API.Solr是基于Lucene的,Lucene 支持强大的匹配能力,如短语,通配符,连接, ...
- R语言查看栅格值
有这么一个需求,知道栅格上的坐标,想看看这个坐标上的栅格值是多少.坐标长这个样子 那么这样的坐标下的栅格值该怎么看 cellFromXY(the.stack$t1,c( -1505000,683500 ...
- 前端开发需要掌握的SEO的知识点
SEO 工作的目的 seo 的工作目的是为了让网站更利于让各大搜索引擎抓取和收录,增加产品的曝光率. SEO 注意事项 1. 网站 TDK 标签的设置.title,description,keywor ...