LuaJIT的跟踪编译器是如何工作的?
2013-11-29 3:5:40
收藏:0
阅读:116
评论:2
我一直在研究JIT和LuaJIT的跟踪编译器,最终我有了一些问题。
据我所知,LuaJIT的JIT不像Java的HotSpot那样编译热方法,而是编译源自循环的热路径。这是否意味着如果某些东西不源自循环(比如,我从C-API调用Lua函数),那么该代码将永远不会被JIT编译?当你触发另一个循环时会发生什么?第二个循环的路径是否会被JIT,然后新的路径从该循环也被JIT编译,或者第二个循环是相同路径的一部分?
解释器如何选择最优的热路径?假设我有一个整数 -》字符串的哈希表。现在想象我已经调用了table[x],其中x是3和5足够多次,它们已经成为热路径并被JIT编译,那么解释器如何决定要调用哪个JIT码来处理table[x],其中x是4?
还有一件事一直在困扰我。由于路径被编译而不是函数,跟踪编译器是否需要更多的内存?因为你不能真正地重用另一个路径的编译代码,我是说,而且在一般情况下路径可能比单个函数更大…
点赞
用户636967
Mike Pall 在 LuaJIT 邮件列表上以相当详细的方式回复了这个问题。
http://www.freelists.org/post/luajit/How-does-LuaJITs-trace-compiler-work,1
2013-11-29 20:32:30
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
第一部分是需要理解的是 LuaJIT 的 IR 和 Bytecode,你可以在 Wiki 上查看,这是LuaJIT解释器运行和优化的内容,因此对追踪需要编译的内容以及在追踪路径中热点循环的优化(如循环展开)进行决策。
第二个要查看的地方是 LJ FAQ,其中有这样的描述:
虽然非常直率(主要是因为 Mike 关注的是开发而不是文档),但最重要的部分在于最后一句话,源代码非常清晰而且是了解 LuaJIT 如何实现功能的唯一方法。此外,创新特性链接 还会给出更多关于搜索的线索。
维基百科有一个关于跟踪 JIT 的更具描述性的页面,然而,页面底部的论文是您在理解 LJ 源代码中使用的概念时最有用的参考。
以下是一些您可以开始阅读的源代码文件(使用 C 语言编写):