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. C#设计模式(9)——装饰者模式(Decorator Pattern)(转)

    一.引言 在软件开发中,我们经常想要对一类对象添加不同的功能,例如要给手机添加贴膜,手机挂件,手机外壳等,如果此时利用继承来实现的话,就需要定义无数的类,如StickerPhone(贴膜是手机类).A ...

  2. MySql使用存储过程清除数据库所有表数据,保存数据结构

    BEGIN DECLARE strClear VARCHAR(256); DECLARE done INT DEFAULT 0; #定义游标 DECLARE curOne CURSOR FOR sel ...

  3. [Android] macOS的Android Studio快捷键

    - 快速输入serialVersionUID - - 设置,左上角,Android Studio -> Preferences -> 搜索“Serializable class witho ...

  4. NOIP2009(codevs1173)最优贸易

    题目大意:给你一张有n个点m条边的有向图,每个点有一个权值,求一条1到n的路径,使得这条路径上存在两个点且他们的权值差最大. 思路:用dis[i]]记录从1到i的路径中所能得到两点间权值差的最大值,然 ...

  5. n皇后问题——关于斜线的编号

    题目大意:在n*n的棋盘中,放置n个皇后(同一行.同一列.同一斜线,只有一个皇后) 这道题是一道非常经典的dfs模板题,同一行.同一列的判断不是很难,但同一斜线有一定的难度,下面给出关于斜线编号的解决 ...

  6. 0007-20180403-python-自动化基础学习000--while-if 循环实操

    python-自动化基础学习000 Python 3.5.1 (v3.5.1:37a07cee5969, Dec 6 2015, 01:54:25) [MSC v.1900 64 bit (AMD64 ...

  7. 进程间通信之信号量、消息队列、共享内存(system v的shm和mmap)+信号signal

    进程间通信方式有:System v unix提供3种进程间通信IPC:信号量.消息队列.共享内存.此外,传统方法:信号.管道.socket套接字. [注意上述6种方式只能用户层进程间通信.内核内部有类 ...

  8. spring jar包依赖

  9. YII1 增、删、改、查数据库操作

    增 //注意插入的时候 是用的new Post $objectPost = new Post; $objectPost->username = $username; $objectPost-&g ...

  10. Guitar Pro特殊符号讲解之附点音符

    今天要讲解Guitar Pro里附点音符的作用,附点音符也是大家在编曲做谱的时候,经常需要使用的一个符号,它在Guitar Pro分为附点和双附点. 附点:记在音符符头右边的圆点,用以增长音符的时值. ...