加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

LuaJIT的跟踪编译器如何工作?

发布时间:2020-12-15 00:27:37 所属栏目:大数据 来源:网络整理
导读:我一直在阅读JIT和LuaJIT的跟踪编译器,最后我提出了一些问题. 根据我的理解,LuaJIT的JIT不会像Java的HotSpot那样编译热门方法,它会编译源自循环的热路径.这是否意味着如果某些东西不是来自循环(比方说,我从C-api调用Lua函数)那么代码永远不会被jitted?当你
我一直在阅读JIT和LuaJIT的跟踪编译器,最后我提出了一些问题.

根据我的理解,LuaJIT的JIT不会像Java的HotSpot那样编译热门方法,它会编译源自循环的热路径.这是否意味着如果某些东西不是来自循环(比方说,我从C-api调用Lua函数)那么代码永远不会被jitted?当你遇到另一个循环时会发生什么?第二个循环的路径是JIT,然后是来自该循环的新路径,或者第二个循环是否是同一路径的一部分?

口译员如何选择最佳的热门路径?假设我有一个整数的哈希表 – >字符串.现在假设我调用table [x],其中x为3和5,它们已成为热路径和jitted,解释器如何决定哪个jitted代码调用table [x],其中x为4?

另一件令我绞尽脑汁的事情.由于路径是编译的,而不是函数,跟踪编译器是否需要更多的内存?既然你不能真正重用其他路径的编译代码我的意思,因为在一般情况下路径可能比单个函数大…

解决方法

Mike Pall在LuaJIT邮件列表中做了非常详细的回复.
http://www.freelists.org/post/luajit/How-does-LuaJITs-trace-compiler-work,1

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读