Java AOT 编译框架 GraalVM 快速入门

GraalVM 诞生的背景 过去 20 多年,Java 通过语言层虚拟化,实现了平台无关、架构中立等特性,彻底屏蔽了不同操作系统、不同指令集架构带来的差异,因而 Java 语言也取得了巨大的成功。但随着云原生时代的到来,面对相同的问题,云原生选择了操作系统层虚拟化方案——通过容器实现不可变基础设施,将程序连同它的运行环境一起封装到镜像里,这种方案越来越成为一种主流的应用程序分发方式。 云原...

GraalVM

无关性的基石之 Java 字节码技术初探

前言 熟悉 Java 语言的朋友应该都听过 Write Once, Run Anywhere. 这样的口号,它主要阐述地是 Java 语言的跨平台特性。工程师只需要编写一次 Java 源码,再通过 Java 编译器将源码编译为字节码文件,就可以很方便地在不同操作系统的 JVM 上进行分发运行。Java 字节码技术是 Java 语言实现平台无关性的基石,也是学习 JVM 虚拟机实现的基础,了...

JVM

ANTLR 解析性能优化指南

本文翻译自 Improving the performance of an ANTLR parser,主要介绍了 Antlr 解析性能优化相关的经验,文中也增加了笔者个人的理解,期望对广大 Antlr 用户有所帮助。 前言 很多人问我们如何提高解析器的性能,有时解析器是用一些旧库完成的,有时解析器是用 ANTLR 创建的。在本文中,我们提供了一些关于提高 ANTLR 解析器性能的建议。...

Antlr

Java 虚拟机指令操作码和助记符映射关系

前言 本文整理了 Java 虚拟机指令操作码和助记符之间的映射关系,可以用于日常学习 Java 字节码时快速查阅。需要注意的是,操作码 186 对应的 invokedynamic 指令是 JDK 7 版本新增的指令,在 JDK 7 之前的版本没有该指令。 常量 Constants 字节码(十进制) 字节码(十六进制) 助记符 指令含义 00 0x00 nop 无操作 0...

JVM

深度探究 Apache Calcite SQL 校验器实现原理

注意:本文基于 Calcite 1.35.0 版本源码进行学习研究,其他版本可能会存在实现逻辑差异,对源码感兴趣的读者请注意版本选择。 前言 在上一篇 Apache Calcite System Catalog 实现探究中,我们介绍了经典的数据库处理流程,包括:SQL 解析、SQL 绑定、SQL 优化以及计划执行。SQL 绑定主要的作用是将 SQL 解析生成的 AST 和数据库的元数据...

Calcite
12347