在Java中,JVM(例如HotSpot)能够进行JIT编译,并且该技术用于通过将字节码编译为本机代码来加速执行.我的问题是,这在技术上是如何发生的?我的理解是,现代处理器将内存区域标记为只读部分,以及可执行部分以防止恶意代码执行.因此,JVM无法真正将新的“可执行代码”写入它可以访问的内存空间(即自修改代码).所以,我猜测JVM生成本机代码,将其写入文件然后使用操作系统服务将该本机代码动态加载到内存中,并维护本机代码(函数)位置的地址的一些内部映射表在操作系统加载了这个动态代码之后,在内存中,它可以分支到那些本机指令.
我确实看到了这个答案:How is JIT compiled code injected in memory and executed?,但我很困惑为什么操作系统会允许用户程序READ EXECUTE内存区域.其他操作系统,即Linux等提供类似的东西,以便JIT工作吗?
有人可以帮助澄清我的理解吗?
JVM可能会在内存中生成机器代码,而不使用任何磁盘文件.它的JIT机器可能只是在可执行内存中写入字节.
请注意,JVM可能不希望更改生成的机器代码保护(它可能会生成可写和可执行内存段中的所有机器代码),因为它自己生成了代码,因此可以确保不会做坏事(阅读约proof-carrying code).
阅读Just-in-time compilation和HotSpot以及Virtual Memory维基页面,尝试分析一些java进程…
有些JVM是免费软件(例如OpenJdk中的那个),你可以研究它们的源代码.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。