当前位置:  编程技术>综合
本页文章导读:
    ▪探索Lua5.2内部实现:虚拟机指令(6)FUNCTION       原文 name args desc OP_CALL A B C A B C   R(A), ... ,R(A+C-2) := R(A)(R(A+1), ... ,R(A+B-1)) CALL执行一个函数调用。寄存器A中存放函数对象,所有参数按顺序放置在A后面的寄存器中。B-1.........
    ▪newLISP Ubuntu环境安装      首先下载最新的Ubuntu系统的安装包:http://www.newlisp.org/downloads/newlisp_10.4.5-utf8_i386.deb然后安装:dpkg -i ./newlisp_10.4.5-utf8_i386.deb现在看看怎么用。运行newlisp,报错:/usr/bin/newlisp: error while loading sha.........
    ▪windows中将绿色程序添加到鼠标右键      1.绿色软件是很多人的最爱,但是也有一些问题,需要我们来解决,那就是如何将常用的软件添加到鼠标右键,比如,notepad++绿色版的软件,我们想让她能够出现在鼠标右键中,这样当.........

[1]探索Lua5.2内部实现:虚拟机指令(6)FUNCTION
    来源: 互联网  发布时间: 2013-11-19

原文

name args desc OP_CALL A B C A B C   R(A), ... ,R(A+C-2) := R(A)(R(A+1), ... ,R(A+B-1))

CALL执行一个函数调用。寄存器A中存放函数对象,所有参数按顺序放置在A后面的寄存器中。B-1表示参数个数 。如果参数列表的最后一个表达式是变长的,则B会设置为0,表示使用A+1到当前栈顶作为参数。函数调用的返回值会按顺序存放在从寄存器A开始的C-1个寄存器中。如果C为0,表示返回值的个数由函数决定。

f();
	1	[1]	GETTABUP 	0 0 -1	; _ENV "f"
	2	[1]	CALL     	0 1 1
	3	[1]	RETURN   	0 1

第一行取得全局变量f的值,保存到寄存器0。第二行CALL调用寄存器0中的函数,参数和返回值都是0。

local t = {f(...)};
	1	[1]	NEWTABLE 	0 0 0
	2	[1]	GETTABUP 	1 0 -1	; _ENV "f"
	3	[1]	VARARG   	2 0
	4	[1]	CALL     	1 0 0
	5	[1]	SETLIST  	0 0 1	; 1
	6	[1]	RETURN   	0 1

第一行NETTABLE创建一个表放到寄存器0中。第二行获取全局变量f放到寄存器1中。第三行VARARG表示使用当前函数的变长参数列表。第四行的CALL调用寄存器1中的函数,B为0,代表参数是变长的。前面讲过,如果表的构造的最后一项是多返回值的表达式,则这个表会接受所有的返回值。这里就是这种情况,表的构造会接受函数所有的返回值,所以C也为0。


name args desc OP_TAILCALL A B C A B C   return R(A)(R(A+1), ... ,R(A+B-1))

如果一个return statement只有一个函数调用表达式,这个函数调用指令CALL会被改为TAILCALL指令。TAILCALL不会为要调用的函数增加调用堆栈的深度,而是直接使用当前调用信息。ABC操作数与CALL的意思一样,不过C永远都是0。TAILCALL在执行过程中,只对lua closure进行tail call处理,对于c closure,其实与CALL没什么区别。

return f();
	1	[1]	GETTABUP 	0 0 -1	; _ENV "f"
	2	[1]	TAILCALL 	0 1 0
	3	[1]	RETURN   	0 0
	4	[1]	RETURN   	0 1

上面如果f是一个lua closure,那么执行到第二行后,此函数就会返回了,不会执行到后面第三行的RETURN。如果f是一个c closure,那就和CALL一样调用这个函数,然后依赖第三行的RETURN返回。这就是为什么TAILCALL后面还会己跟着生成一个RETURN的原因。


name args desc OP_RETURN A B return R(A), ... ,R(A+B-2)

RETURE将返回结果存放到寄存器A到寄存器A+B-2中。如果返回的为变长表达式,则B会被设置为0,表示将寄存器A到当前栈顶的所有值返回。

return 1;
	1	[1]	LOADK    	0 -1	; 1
	2	[1]	RETURN   	0 2
	3	[1]	RETURN   	0 1

RETURN只能从寄存器返回数据,所以第一行LOADK先将常量1装载道寄存器0,然后返回。

return ...;
	1	[1]	VARARG   	0 0
	2	[1]	RETURN   	0 0
	3	[1]	RETURN   	0 1
因为返回的为变长表达式,B为0。


name args desc OP_CLOSURE A Bx R(A) := closure(KPROTO[Bx])

CLOSURE为指定的函数prototype创建一个closure,并将这个closure保存到寄存器A中。Bx用来指定函数prototype的id。

local function f()
end
main <test.lua:0,0> (2 instructions at 0x102a016f0)
0+ params, 2 slots, 1 upvalue, 1 local, 0 constants, 1 function
	1	[2]	CLOSURE  	0 0	; 0x102a019b0
	2	[2]	RETURN   	0 1
constants (0) for 0x102a016f0:
locals (1) for 0x102a016f0:
	0	f	2	3
upvalues (1) for 0x102a016f0:
	0	_ENV	1	0

function <test.lua:1,2> (1 instruction at 0x102a019b0)
0 params, 2 slots, 0 upvalues, 0 locals, 0 constants, 0 functions
	1	[2]	RETURN   	0 1
constants (0) for 0x102a019b0:
locals (0) for 0x102a019b0:
upvalues (0) for 0x102a019b0:
上面生成了一个主函数和一个子函数,CLOSURE将为这个索引为0的子函数生成一个closure,并保存到寄存器0中。


name args desc OP_VARARG A B R(A), R(A+1), ..., R(A+B-2) = vararg 

VARARG直接对应'...'运算符。VARARG拷贝B-1个参数到从A开始的寄存器中,如果不足,使用nil补充。如果B为0,表示拷贝实际的参数数量。

local a = ...;
	1	[1]	VARARG   	0 2
	2	[1]	RETURN   	0 1
上面第一行表示拷贝B-1个,也就是1个变长参数到寄存器0,也就是local a中。

f(...);
	1	[1]	GETTABUP 	0 0 -1	; _ENV "f"
	2	[1]	VARARG   	1 0
	3	[1]	CALL     	0 0 1
	4	[1]	RETURN   	0 1
由于函数调用最后一个参数可以接受不定数量的参数,所以第二行生成的VARARG的B参数为0。


name args desc OP_SELF A B C

R(A+1) := R(B); R(A) := R(B)[RK(C)]

SELF是专门为“:”运算符准备的指令。从寄存器B表示的table中,获取出C作为key的closure,存入寄存器A中,然后将table本身存入到寄存器A+1中,为接下来调用这个closure做准备。

a:b();
	1	[1]	GETTABUP 	0 0 -1	; _ENV "a"
	2	[1]	SELF     	0 0 -2	; "b"
	3	[1]	CALL     	0 2 1
	4	[1]	RETURN   	0 1
看一下与上面语法等价的表示方法生成的指令:

a.b(a);
	1	[1]	GETTABUP 	0 0 -1	; _ENV "a"
	2	[1]	GETTABLE 	0 0 -2	; "b"
	3	[1]	GETTABUP 	1 0 -1	; _ENV "a"
	4	[1]	CALL     	0 2 1
	5	[1]	RETURN   	0 1
比使用“:"操作符多使用了一个指令。所以,如果需要使用这种面向对象调用的语义时,应该尽量使用”:"。



作者:yuanlin2008 发表于2013-1-13 20:32:01 原文链接
阅读:40 评论:0 查看评论

    
[2]newLISP Ubuntu环境安装
    来源: 互联网  发布时间: 2013-11-19

首先下载最新的Ubuntu系统的安装包:

http://www.newlisp.org/downloads/newlisp_10.4.5-utf8_i386.deb

然后安装:

dpkg -i ./newlisp_10.4.5-utf8_i386.deb

现在看看怎么用。

运行newlisp,报错:

/usr/bin/newlisp: error while loading shared libraries: libreadline.so.6: cannot open shared object file: No such file or directory

那就安装libreadline吧。

sudo apt-get install libreadline6 libreadline6-dev

安装完后,仍然报这个错。检查一下libreadline.so.6居然在这里:

/lib/x86_64-linux-gnu/libreadline.so.6

那就添加一个链接吧:

ln -s /lib/x86_64-linux-gnu/libreadline.so.6 /usr/lib/

再运行newlisp,还是报错。

newlisp
newlisp: error while loading shared libraries: libreadline.so.6: wrong ELF class: ELFCLASS64


真是无语。下载源代码重新编译吧。先删除前面的链接文件。再卸载掉之间安装的newlisp.

用apt-get autoremove newlips即可。


这里下载:http://sourceforge.net/projects/newlisp/files/newlisp-10.4.5.tgz/download

解压后进入目录,运行make,报错:

newlisp.h:36:19: fatal error: ffi.h: No such file or directory

安装libffi-dev

apt-get install libffi-dev

再运行make,成功了,然后运行sudo make install

安装完成。

现在运行newlisp,不带参数进入交互模式,看到:

root@chenshu-beijing:/usr/src/newlisp-10.4.5# newlisp
newLISP v.10.4.5 64-bit on Linux IPv4/6 UTF-8 libffi, execute 'newlisp -h' for more info.

> 

成功了。可以运行lisp语句(+ 2 5)。

退出按C-c 然后根据提示按x.







作者:sheismylife 发表于2013-1-13 20:26:02 原文链接
阅读:37 评论:0 查看评论

    
[3]windows中将绿色程序添加到鼠标右键
    来源: 互联网  发布时间: 2013-11-19

1.绿色软件是很多人的最爱,但是也有一些问题,需要我们来解决,那就是如何将常用的软件添加到鼠标右键,比如,notepad++绿色版的软件,我们想让她能够出现在鼠标右键中,这样当我们遇到一个文件想用notepad++打开时,只要用鼠标右键就可以直接打开了。


2.下面介绍如何把一个程序添加到鼠标右键。主要就是修改注册表来实现的。

Windows Registry Editor Version 5.00
[HKEY_CLASSES_ROOT\*\shell]
[HKEY_CLASSES_ROOT\*\shell\Notepad++ Portable]
@="Notepad++ Portable"
[HKEY_CLASSES_ROOT\*\shell\Notepad++ Portable\Command]
@="F:\\Program Files\\Notepad++\\notepad++.exe %1"

将上边的程序保存成a.reg双击就可以导入了。

每一行的意思大致介绍一下,第一行声明注册表版本,第二行进入到shell文件夹,第三行建立Notepad++ Portable文件夹,并取名为“Notepad++ Portable”,第五行在刚才建立的文件夹下建立Commnad命令给出其参数为Notepad++的文件路径即可。

作者:fujiafeihudui 发表于2013-1-13 20:25:36 原文链接
阅读:38 评论:0 查看评论

    
最新技术文章:
▪error while loading shared libraries的解決方法    ▪版本控制的极佳实践    ▪安装多个jdk,多个tomcat版本的冲突问题
▪简单选择排序算法    ▪国外 Android资源大集合 和个人学习android收藏    ▪.NET MVC 给loading数据加 ajax 等待loading效果
▪http代理工作原理(3)    ▪关注细节-TWaver Android    ▪Spring怎样把Bean实例暴露出来?
▪java写入excel2007的操作    ▪http代理工作原理(1)    ▪浅谈三层架构
▪http代理工作原理(2)    ▪解析三层架构……如何分层?    ▪linux PS命令
▪secureMRT Linux命令汉字出现乱码    ▪把C++类成员方法直接作为线程回调函数    ▪weak-and算法原理演示(wand)
▪53个要点提高PHP编程效率    ▪linux僵尸进程    ▪java 序列化到mysql数据库中
▪利用ndk编译ffmpeg    ▪活用CSS巧妙解决超长文本内容显示问题    ▪通过DBMS_RANDOM得到随机
▪CodeSmith 使用教程(8): CodeTemplate对象    ▪android4.0 进程回收机制    ▪仿天猫首页-产品分类
▪从Samples中入门IOS开发(四)------ 基于socket的...    ▪工作趣事 之 重装服务器后的网站不能正常访...    ▪java序列化学习笔记
▪Office 2010下VBA Addressof的应用    ▪一起来学ASP.NET Ajax(二)之初识ASP.NET Ajax    ▪更改CentOS yum 源为163的源
▪ORACLE 常用表达式    ▪记录一下,AS3反射功能的实现方法    ▪u盘文件系统问题
▪java设计模式-观察者模式初探    ▪MANIFEST.MF格式总结    ▪Android 4.2 Wifi Display核心分析 (一)
▪Perl 正则表达式 记忆方法    ▪.NET MVC 给loading数据加 ajax 等待laoding效果    ▪java 类之访问权限
▪extjs在myeclipse提示    ▪xml不提示问题    ▪Android应用程序运行的性能设计
▪sharepoint 2010 自定义列表启用版本记录控制 如...    ▪解决UIScrollView截获touch事件的一个极其简单有...    ▪Chain of Responsibility -- 责任链模式
▪运行skyeye缺少libbfd-2.18.50.0.2.20071001.so问题    ▪sharepoint 2010 使用sharepoint脚本STSNavigate方法实...    ▪让javascript显原型!
▪kohana基本安装配置    ▪MVVM开发模式实例解析    ▪sharepoint 2010 设置pdf文件在浏览器中访问
▪spring+hibernate+事务    ▪MyEclipse中文乱码,编码格式设置,文件编码格...    ▪struts+spring+hibernate用jquery实现数据分页异步加...
▪windows平台c++开发"麻烦"总结    ▪Android Wifi几点    ▪Myeclipse中JDBC连接池的配置
▪优化后的冒泡排序算法    ▪elasticsearch RESTful搜索引擎-(java jest 使用[入门])...    ▪MyEclipse下安装SVN插件SubEclipse的方法
▪100个windows平台C++开发错误之七编程    ▪串口转以太网模块WIZ140SR/WIZ145SR 数据手册(版...    ▪初识XML(三)Schema
▪Deep Copy VS Shallow Copy    ▪iphone游戏开发之cocos2d (七) 自定义精灵类,实...    ▪100个windows平台C++开发错误之八编程
▪C++程序的内存布局    ▪将不确定变为确定系列~Linq的批量操作靠的住...    ▪DIV始终保持在浏览器中央,兼容各浏览器版本
▪Activity生命周期管理之三——Stopping或者Restarti...    ▪《C语言参悟之旅》-读书笔记(八)    ▪C++函数参数小结
▪android Content Provider详解九    ▪简单的图片无缝滚动效果    ▪required artifact is missing.
▪c++编程风格----读书笔记(1)    ▪codeforces round 160    ▪【Visual C++】游戏开发笔记四十 浅墨DirectX教程...
▪【D3D11游戏编程】学习笔记十八:模板缓冲区...    ▪codeforces 70D 动态凸包    ▪c++编程风格----读书笔记(2)
▪Android窗口管理服务WindowManagerService计算Activity...    ▪keytool 错误: java.io.FileNotFoundException: MyAndroidKey....    ▪《HTTP权威指南》读书笔记---缓存
▪markdown    ▪[设计模式]总结    ▪网站用户行为分析在用户市场领域的应用
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3