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;}

    词典是 FORTH 系统的主干,他是系统中全部词以一定的方式链接而成。
    FORTH 系统,词典本身也是被当做一个堆栈来对待。由一个称为词典指针的变量 DP 指着词典上方(高端地址)空白区域的第一个字节,也既下一个可被使用的字节。词 HERE 则把 DP 的值送到参数堆栈的栈顶。
VARIABLE  DP           用户变量,其值为词典上部第一个可被使用的内存地址。
:  HERE    ( - addr )  DP  @  ;    返回词典上方的地址,它告诉编译程序待用的自由存贮区域始于何处
:  ALLOT  ( n - )  DP  +!  ;          使 DP 之值增加 n,也即为了某种目的给词典的区域增加 n 个字节。
:   ,   ( n - )  HERE  !  2  ALLOT ; 把参数堆栈顶上的数 n 送入到词典上部的下一个可用单元,使 DP 之值增加 2 。(把 n 编入词典)
:  C,  ( byte - )  HERE  C!  1  ALLOT  ;

   词典是由一些在逻辑上独立的词表所构成。把一组在逻辑上密切相关的词所链接形成的词表称为是一个词汇。
CONTEXT  ( - addr )  是一个数组,由它决定首先搜索哪一个词汇,接着搜索哪几个词汇(如果没找到的话)。
CURRENT  ( - addr )  是一个变量,由它决定新添加到词典中的定义属于哪一个词汇。在 Fig-Forth 中它还决定继 CONTEXT 词汇之后所要搜索的词汇,如果指定词在 CONTEXT 词汇中没有找到。
Fig-Forth 中词典搜索
INTERPRET -> -FIND -> (FIND)
:  INTERPRET  ( - )      逐个顺序处理从输入流中分离出来的字符串;或是执行或是编译由当时系统的状态决定。
       BEGIN         开始解释程序循环
            -FIND  ( - pfa b tf , or ff )       把从输入流中检测到的下一个字符串送到 HERE 处。首先搜索 context 词汇,继之搜索 current 词汇,核实在词典中是否有与在 HERE 处的字符串同名的定义。若有,被找到之词的参数域地址 pfa,长度字节 b 及为真标志 tf 留在堆栈上;若没有,堆栈上仅留下为假标志 ff 。 
       AGAIN  ;


:  -FIND  ( - pfa b tf , or ff )
            BL  WORD     把以空格为终止符的下一个字符串从输入流中分离出来,并将它送到词典的顶部(HERE 处)
            HERE    有待去词典中发现的字符串的地址
            CONTEXT  @  @   取出在 context 词汇中最后一个(最新)一个被定义词的名字域地址 nfa ,词典搜索行将开始。
            (FIND)   (addr1 addr2 - pfa b tf , or ff)  CODE 词,承担具体搜索工作。addr1是有待被搜索的字符串的地址,addr2是被搜索区的起始地址。(FIND) 从堆栈顶上给出的地址出发搜索词典,以求发现和堆栈上的第二个地址(addr1)处的字符串相符合的名字。若找到,返回相符定义的 pfa , 长度字节以及为真标志。若未找到则仅返回一个假标志。
            DUP  0=    检查栈顶标志。
            IF           在 context 词汇中未找到同名的定义
                 DROP       丢弃假标志
                 HERE          重新取得字符串的地址。
                 CURRENT  @  @          取出在 current 词汇中最后一个被定义的词的 nfa。
                 (FIND)           搜索 current 词汇。
            ENDIF  ;
    // Fig-Forth 中首先搜索 context 词汇,以求发现一个同名定义,若没有则在搜索 current 词汇。一个词汇是由定义词 VOCABULARY 创立的,故一个词汇的词汇名本身也是词典中的一个条目。在一个词汇名的参数域中保存有该词汇中最后一个被定义的词的名字域地址 nfa ,而保存该最后一个词的 nfa 的单元是被 CONTEXT 或 CURRENT 所指着,如果该词汇是 context 词汇或 current 词汇的话。所以在 -FIND 中,CONTEXT @ @ 以及 CURRENT @ @ 提供将被搜索的词汇中的第一个词。

Forth 词典和词汇的更多相关文章

  1. C++第15周(春)项目3 - OOP版电子词典(一)

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759.内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序中须要的相 ...

  2. 第14周 项目三-OOP版电子词典

    做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对比的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开. (1)编程序,由用户输入英文词.显示词性和中文释义. ...

  3. wxWidgets+wxSmith版电子词典

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序须要的相关 ...

  4. C++第15周(春)项目3 - OOP版电子词典(二)

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序须要的相关 ...

  5. OOP版电子词典

    输入代码: /* * Copyright (c) 2014, 烟台大学计算机学院 * All rights reserved. * 文件名:sum123.cpp * 作 者:林海云 * 完毕日期:20 ...

  6. 第十四周(OOP版电子词典)

    /* *copyright(c) 2015,烟台大学计算机学院 *All rights reserved. *文件名:第十四周(OOP版电子词典) *作者:王忠 *完毕日期:2015.6.10 *版本 ...

  7. 侣行APP

    本次要做的是团队共同完成一个项目.由队长组织,全体队员一起讨论分析并完成一款APP的需求调研,分析等工作. 1.团队介绍 队长:杨晓帅 队员                               ...

  8. 看美剧英文字幕学英语的利器——“深蓝英文字幕助手”简介

    我从初中开始基本上就是一个英语很烂的人,数理化再好有什么用,工作了,结果发现数理化都没啥用,最有用的还是当年学的最烂的英语.于是在2011年年底开始了学习英语的课程,在学习的过程中,外教经常会放英剧美 ...

  9. 2013级C++第15周(春)项目——输入输出流及文件文件操作

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759.内有完整教学方案及资源链接 本周程序阅读及程序调试中须要的文件,请到htt ...

随机推荐

  1. Vue滑动删除与修改

    Vu+element实现 <template> <div class=""> <div class="slider"> &l ...

  2. [Android] TextView上同时显示图标和文字

    需求场景 +----------------------------+ | Icon TEXT | +----------------------------+ 当然,可以使用LineLayout,包 ...

  3. keepalived weight正负值问题(实现主服务器nginx故障后迅速切换到备服务器)

    有两台负载均衡,lb01,lb02.  lb02, priority值为100 编辑keepalived配置文件   vim /etc/keepalived/keepalived.conf ! Con ...

  4. 知识在与温故、总结-再读CLR

    序 CLR,通用语言运行时,每个.Net 程序猿,都会第一时间接触到.记得2008年,第一次学习Jeffrey Richter的CLR Via C#,读的懵懵懂懂,大抵因为编码太少,理解的只是概念和皮 ...

  5. 项目中常用的javascript/jquery操作

    1.判断复选框是否被选中? $("#cpuWindow").is(':checked'); 2.设置复选框被选中: $("#cpuWindow").prop(& ...

  6. [转载]ORACLE日期时间函数大全

    ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02   13:45:25为例)           Year:              yy two digits 两位年 ...

  7. 5、Spring-Kafka3

    3. Introduction This first part of the reference documentation is a high-level overview of Spring fo ...

  8. 定位bug的基本要求

    很多人觉得qa只是负责发现问题,这个实在太狭隘了,现代qa除了发现问题这种基本功外,定位问题,提出解决方案,提出预防方案也是要掌握的技能.这里先说定位问题的要求,定位问题要向深入,前提当然是对功能.产 ...

  9. Html 符号

    Html  符号 往网页中输入特殊字符,需在html代码中加入以&开头的字母组合或以&#开头的数字. 下面就是以字母或数字表示的特殊符号大全.   常用 < < 小于号或显 ...

  10. Linux 系统最大TCP连接数 调优

    Linux系统TCP最大连接数 Linux系统可接连接到最大的TCP连接数,高并发情况下可进行扩展加大,最大为65536. 限制最大TCP连接数 修改文件:/etc/sysctl.conf 生效命令: ...