编译原理------------------------------------------PL/O编程语言的实现

一。PL/O语言与类pcode的描述

指令功能表
LIT 0 a 将常数值取到栈顶,a为常数值
LOD l a 将变量值取到栈顶,a为偏移量,l为层差
STO l a 将栈顶内容送入某变量单元中,a为偏移量,l为层差
CAL l a 调用过程,a为过程地址,l为层差
INT 0 a 在运行栈中为被调用的过程开辟a个单元的数据区
JMP 0 a 无条件跳转至a地址
JPC 0 a 条件跳转,当栈顶布尔值非真则跳转至a地址,否则顺序执行
OPR 0 0 过程调用结束后,返回调用点并退栈
OPR 0 1 栈顶元素取反
OPR 0 2 次栈顶与栈顶相加,退两个栈元素,结果值进栈
OPR 0 3 次栈顶减去栈顶,退两个栈元素,结果值进栈
OPR 0 4 次栈顶乘以栈顶,退两个栈元素,结果值进栈
OPR 0 5 次栈顶除以栈顶,退两个栈元素,结果值进栈
OPR 0 6 栈顶元素的奇偶判断,结果值在栈顶
OPR 0 7 
OPR 0 8 次栈顶与栈顶是否相等,退两个栈元素,结果值进栈
OPR 0 9 次栈顶与栈顶是否不等,退两个栈元素,结果值进栈
OPR 0 10 次栈顶是否小于栈顶,退两个栈元素,结果值进栈
OPR 0 11 次栈顶是否大于等于栈顶,退两个栈元素,结果值进栈
OPR 0 12 次栈顶是否大于栈顶,退两个栈元素,结果值进栈
OPR 0 13 次栈顶是否小于等于栈顶࿰

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue-loader 是一个用于解析和转换 Vue 单文件组件(.vue 文件)的 webpack loader。下面是 vue-loader 的工作原理: 1. 预处理:vue-loader 接收到一个 .vue 文件后,首先会对其进行预处理,将其拆分为三个部分:template、script 和 style。 2. 解析:vue-loader 会对 template、script 和 style 部分进行解析。 - 对于 template 部分,vue-loader 使用 compiler 将其转换为 render 函数,然后将其与所在的 script 部分合并。这允许开发者以编写 HTML 模板的方式来编写 Vue 组件。 - 对于 script 部分,vue-loader 解析其中的 ES6+ 语法,并且将其转换为浏览器可识别的 JavaScript 代码。 - 对于 style 部分,vue-loader 会将样式代码转换为 JavaScript 对象,并使用 CSS-loader 进一步处理。 3. 组件资源处理:vue-loader 还会处理组件中引用的资源,如图片、字体等。它会将这些资源的路径进行转换,并使用 file-loader 或 url-loader 对其进行加载。 4. 热重载:vue-loader 可以与 webpack-dev-server 或 webpack-hot-middleware 配合,实现在开发过程中的热重载功能。它会监听 .vue 文件的变化,并在文件发生改变时重新编译和更新组件。 总的来说,vue-loader 通过对 .vue 文件中的模板、脚本和样式进行解析和转换,实现了将 Vue 单文件组件转换为可以在浏览器中运行的 JavaScript 代码,并提供了热重载功能。这样可以提高开发效率,同时也方便了组件化开发的实现

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值