secd machine是一种比较基础的虚拟机设计。一般是作为函数式语言的底层虚拟机。

secd machine的“secd”四个字母分别指的是这种虚拟机的核心Stack, Environment, Control, Dump,一般也称作寄存器。

secd machine 是一种stack-based虚拟机。

Stack一般是存放运算数据和结果

Environment保存的是环境变量,一般是函数调用里的参数以及局部变量

Control保存的是虚拟机指令

Dump保存的是函数调用时的调用帧数据。

secd machine常用的指令有如下一些。

  

  • nil 将一个nil push入stack
  • s e (NIL.c) d => (nil.s) e c d
  • ldc 将一个常量push入stack,如果区分类型也可以扩展成多个ld指令
  • s e (LDC x.c) d => (x.s) e c d
  • ld 从环境中加载一个变量push入stack,因为env是分层级的,所以一般是ld [1,2] 类似的形式。
  • s e (LD [y x].c) d => (locate([y x], e).s) e c d
  • sel 这个指令是为了实现条件选择,sel有两个参数,执行时会pop出stack的一个值,判断如果是真,则将Control寄存器设置为第一个参数,否则就设置为第二个参数。同时会将当前的C寄存器中的值push到Dump寄存器。
  • (x.s) e (SEL ct cf.c) d => s e c? (c.d)
    where c? is (if (not= x false) ct cf)
  • join 和sel共用的,是在sel一条选择语句执行完时,将sel指令push到D寄存器里的指令pop出来,然后设置C寄存器。
  •   
    s e (JOIN.c) (c'.d) => s e c' d
  • ldf 将其参数当做一个函数加载到stack,创建函数时会加上当前的环境。
  • s e (LDF f.c) => ([f e].s) e c d
  • ap 从stack里pop出一个closure对象和一个函数参数对象,将SEC寄存器push到D寄存器,closure携带的的env会替换E寄存器,函数体替换C寄存器,并将参数列表push到env,
  • ([f e'] v.s) e (AP.c) d => nil (v.e') f (s e c.d)
  • rtn  将返回值从stack之中pop出来,将d寄存器中保存的SEC值pop出来,赋值给SEC寄存器,然后将返回值push到stack里
  •    
    (x.z) e' (RTN.q) (s e c.d) => (x.s) e c d
  • dum push一个空环境到当前环境中
  • s e (DUM.c) d => s (nil.e) c d
  • rap 和ap不同之处,是会将参数替换dum的空环境,dum和rap联合能实现递归。
  • ([f (nil.e)] v.s) (nil.e) (RAP.c) d
    =>
    nil (rplaca((nil.e), v).e) f (s e c.d)

参考了wiki和pysecd和 这份代码

SECD machine简介的更多相关文章

  1. SECD machine

    SECD machine 对程序语言理论的理解 程序语言理论主要研究语法.语义及语言的实现.编程语言有语法,各种数学逻辑.结构化数据都有语法.乔姆斯基的语言体系及巴科斯范式是语法分析的基础,语法分析将 ...

  2. Docker Machine 简介

    Docker Machine 是什么? Docker Machine 是 Docker 官方提供的一个工具,它可以帮助我们在远程的机器上安装 Docker,或者在虚拟机 host 上直接安装虚拟机并在 ...

  3. Docker Machine 详解

    笔者在<Docker Machine 简介>一文中简单介绍了 Docker Machine 及其基本用法,但是忽略的细节实在是太多了.比如 Docker 与 Docker Machine ...

  4. 用 Docker Machine 创建 Azure 虚拟主机

    搭建环境向来是一个重复造轮子的过程,Docker Machine 则把用户搭建 Docker 环境的各种方案汇集在了一起.笔者在<Docker Machine 简介>一文中演示了使用 Do ...

  5. Docker Machine的使用

    前面两篇文章(<Asp.Net Core 发布到 Docker(Linux Centos 虚拟机,使用Dockerfile)> <Docker Compose的使用>),简单介 ...

  6. Docker学习—Machine

    前言 前面<Docker学习-Compose>文中介绍了Compose的使用方式:接下来继续了解docker三剑客之一的 Machine: 一.Docker Machine简介 1.什么是 ...

  7. [第十四篇]——Docker Machine之Spring Cloud直播商城 b2b2c电子商务技术总结

    Docker Machine 简介 Docker Machine 是一种可以让您在虚拟主机上安装 Docker 的工具,并可以使用 docker-machine 命令来管理主机. Docker Mac ...

  8. Microsoft 机器学习产品体系对比和介绍

    Microsoft 提供多种多样的产品选项用于生成.部署和管理机器学习模型. 本文将比较这些产品,并帮助你选择所需的产品,以便最有效地开发机器学习解决方案. 机器学习产品 描述 作用 Azure云端服 ...

  9. Continuation-passing style

    Continuation-passing style 参考书籍: EOPL (  Essentials of Programming Languages, 3rd Edition ) 作者:知乎用户链 ...

随机推荐

  1. Python基础篇【第8篇】: Socket编程(二)SocketServer

    SocketServer 在上一篇文章中我们学习了利用socket模块创建socket通信服务,但细心学习后就会发现利用socket模块创建的服务无法进行多进程的处理,当需要进行大量请求处理时,请求就 ...

  2. 安装centOS分区的图解记录

    要将linux的boot loader安装在MBR上,才能起到多重引导的作用.

  3. android sdk manager 代理设置(送给牛逼的)

    解决android sdk更新慢的问题(公司竟然把sdk更新给墙了). 第一步:如下图 第二部:进入代理设置页面,进行设置.如下图  

  4. AX 2012 在Grid 中添加image标识状态

    refer to :http://kiwiaxguy.blogspot.hk/2013/10/displaying-image-on-form-grid-in.html

  5. js输出到控制台

    console.log(object[, object, ...])在控制台输出一条消息.如果有多个参数,输出时会用空格隔开这些参数. 第一个参数可以是一个包含格式化占位符输出的字符串,例如: con ...

  6. 规则引擎集成接口(八)Java接口实例

    接口实例 右键点击“对象库” —“添加接口实例”,如下图: 弹出如下窗体: 输入接口的参数信息: 点击接口“求和”,选择选项卡“求和操作”,点击添加图标   ,如下: 弹出如下窗体,勾选方法“coun ...

  7. tomcat8和7关于自定义tag的处理区别

    今天将一直运行在tomcat-7.0.29(jdk1.6)上的应用迁移到tomcat-8.0.26(jdk1.7)上面,老显示如下错误: org.apache.jasper.JasperExcepti ...

  8. 2.3 ARM寄存器详解

    一共有37个寄存器 1. 31个通用寄存器 2. 6个状态寄存器 R13作为堆栈指针 R14链接寄存器 1.保存函数返回地址 2. 异常返回地址 R15程序计数器(PC指针) 程序状态寄存器 只有在异 ...

  9. linux命令之chmod 2011.11.24转载于网络

    使用权限 : 所有使用者 使用方式 : chmod [-cfvR] [--help] [--version] mode file... 说明 : Linux/Unix 的档案调用权限分为三级 : 档案 ...

  10. AndroidStudio中activity实现去掉标题栏

    1.在代码中实现 this.requestWindowFeature(Window.FEATURE_NO_TITLE) 这段代码需要放在setContentView()前面 2.设置在Manifest ...