当前位置: 首页 > article >正文

Kotlin JVM 注解详解

前言

Kotlin 作为一门现代 JVM 语言,提供了出色的 Java 互操作性。为了更好地支持与 Java 代码的交互,Kotlin 提供了一系列 JVM 相关注解。这些注解不仅能帮助我们控制 Kotlin 代码编译成 Java 字节码的行为,还能让我们的 Kotlin 代码更好地被 Java 代码调用。虽然在日常开发中我们最常用的是 @JvmOverloads、@JvmStatic、@JvmName 和 @JvmField 这几个注解,但 Kotlin 其实还提供了更多强大的 JVM 注解。本文系统地整理下这些注解的作用、使用场景和具体示例,便于开发。
ps:以下整理基于kotlin-stdlib-1.7.10.jar!\kotlin\jvm\JvmInline.class

目录

  • @JvmOverloads
  • @JvmStatic
  • @JvmName
  • @JvmMultifileClass
  • @JvmPackageName
  • @JvmSynthetic
  • @Throws
  • @JvmField
  • @JvmSuppressWildcards
  • @JvmWildcard
  • @JvmInline
  • @JvmRecord

@JvmOverloads

作用

为带有默认参数值的函数生成重载方法。

使用场景

当 Kotlin 函数需要被 Java 代码调用时,特别是函数包含默认参数值的情况。

示例

@JvmOverloads
fun greet(name: String, greeting: String = "Hello") {println("$greeting, $name!")
}

编译后的 Java 代码

void greet(String name) {greet(name, "Hello");
}void greet(String name, String greeting) {System.out.println(greeting + ", " + name + "!");
}

@JvmStatic

作用

生成静态方法或静态属性访问器。

使用场景

在 companion object 中定义需要作为静态成员的方法或属性。

示例

class MyClass {companion object {@JvmStaticfun staticMethod() { }@JvmStaticvar staticProperty: String = ""}
}

@JvmName

作用

指定生成的 Java 类或方法的名称。

使用场景

  • 解决签名冲突
  • 自定义生成的 Java 代码名称
  • 改善 Java 代码的可读性

示例

@JvmName("filterString")
fun filter(list: List<String>) { }@JvmName("filterInt")
fun filter(list: List<Int>) { }

@JvmMultifileClass

作用

指示编译器生成多文件类,将多个文件中的顶级函数和属性合并到一个类中。

使用场景

需要将分散在多个文件中的相关功能组织在一起时。

示例

// File1.kt
@JvmName("Utils")
@JvmMultifileClass
fun function1() { }// File2.kt
@JvmName("Utils")
@JvmMultifileClass
fun function2() { }

@JvmPackageName

作用

更改生成的 .class 文件的 JVM 包名。

使用场景

需要自定义生成的 Java 代码的包名时。

注意

  • 内部注解,不推荐直接使用
  • 自 Kotlin 1.2 版本引入

@JvmSynthetic

作用

在 Java 字节码中设置 ACC_SYNTHETIC 标志,使目标对 Java 代码不可见。

使用场景

需要隐藏 Kotlin 特定的目标,使其对 Java 代码不可见,但保持对 Kotlin 代码可见。

示例

@JvmSynthetic
fun internalFunction() { }

@Throws

作用

指定函数编译为 JVM 方法时应声明的异常。

使用场景

需要从 Kotlin 代码中抛出 Java 检查异常时。

示例

@Throws(IOException::class)
fun readFile() { }

编译后的 Java 代码

void readFile() throws IOException { }

@JvmField

作用

指示编译器不要为属性生成 getter/setter,而是将其作为字段暴露。

使用场景

需要将 Kotlin 属性作为 Java 字段使用时。

示例

class MyClass {@JvmFieldvar field: String = ""
}

@JvmSuppressWildcards

作用

控制是否生成通配符。

使用场景

需要控制泛型类型参数的 Java 表示时。

示例

@JvmSuppressWildcards
fun process(list: List<String>) { }

@JvmWildcard

作用

为带声明点变异的类型参数生成通配符。

使用场景

需要控制泛型类型参数的 Java 表示时。

示例

fun process(@JvmWildcard list: List<String>) { }

@JvmInline

作用

指定值类为内联类。

使用场景

创建零开销的类型安全包装器。

示例

@JvmInline
value class Password(val value: String)

特点

  • 只能有一个主构造函数参数
  • 参数必须是不可变的(val)
  • 不能有 backing field
  • 不能有 init 块
  • 不能有 lateinit 属性

@JvmRecord

作用

指示编译器将类标记为记录类。

使用场景

创建不可变的数据类。

示例

@JvmRecord
data class Person(val name: String, val age: Int)

特点

  • 自 Kotlin 1.5 版本引入
  • 生成 toString、equals、hashCode 方法
  • 适用于不可变数据模型

最佳实践

  1. 选择合适的注解

    • 根据具体需求选择合适的注解
    • 考虑 Java 互操作性的需求
    • 注意注解的版本兼容性
  2. 性能考虑

    • 使用 @JvmInline 减少运行时开销
    • 合理使用 @JvmField 避免不必要的 getter/setter
    • 注意 @JvmStatic 的使用场景
  3. 代码可维护性

    • 使用 @JvmName 提高代码可读性
    • 使用 @Throws 明确异常处理
    • 使用 @JvmSynthetic 控制 API 可见性
  4. 版本兼容性

    • 注意注解的引入版本
    • 考虑向后兼容性
    • 关注 Kotlin 版本更新

相关文章:

Kotlin JVM 注解详解

前言 Kotlin 作为一门现代 JVM 语言&#xff0c;提供了出色的 Java 互操作性。为了更好地支持与 Java 代码的交互&#xff0c;Kotlin 提供了一系列 JVM 相关注解。这些注解不仅能帮助我们控制 Kotlin 代码编译成 Java 字节码的行为&#xff0c;还能让我们的 Kotlin 代码更好地…...

将 node.js 项目作为后台进程持续运行

将 node.js 项目作为后台进程持续运行 方法 1&#xff1a;使用 pm2&#xff08;生产环境推荐&#xff09; 安装 pm2&#xff08;Node.js 进程管理器&#xff09;&#xff1a;npm install pm2 -g启动应用&#xff1a;pm2 start hd/src/app.js --name "my-app"常用命…...

【PhysUnits】15.5 引入P1后的标准化表示(standardization.rs)

一、源码 这段代码实现了一个类型级别的二进制数标准化系统&#xff0c;主要用于处理二进制数的前导零和特殊值的简化。 use super::basic::{Z0, P1, N1, B0, B1, NonNegOne, NonZero};/// 处理 B0<H> 类型的标准化 /// Standardization for B0<H> types /// ///…...

MySQL-5.7 修改密码和连接访问权限

一、MySQL-5.7 修改密码和连接权限设置 修改密码语法 注意&#xff1a;rootlocalhost 和 root192.168.56.% 是两个不同的用户。在修改密码时&#xff0c;两个用户的密码是各自分别保存&#xff0c;如果两个用户密码设置不一样则登陆时注意登陆密码 GRANT ALL PRIVILEGES ON …...

tauri2项目打开某个文件夹,类似于mac系统中的 open ./

在 Tauri 2 项目中打开文件夹 在 Tauri 2 项目中&#xff0c;你可以使用以下几种方法来打开文件夹&#xff0c;类似于 macOS 中的 open ./ 命令功能&#xff1a; 方法一&#xff1a;使用 shell 命令 use tauri::Manager;#[tauri::command] async fn open_folder(path: Strin…...

企业文件乱、传输慢?用群晖 NAS 构建安全高效的共享系统

在信息化办公不断加速的今天&#xff0c;企业对文件存储、共享与安全管理的需求愈发严苛。传统文件共享方式效率低下、权限混乱、远程访问困难&#xff0c;极大影响了协同办公效率。此时&#xff0c;一套可靠、高效、安全的文件共享解决方案便成为众多企业的“刚需”。 这正是…...

防爆手机VS普通手机,区别在哪里?

在加油站掏出手机接打电话、在化工厂车间随手拍照记录……这些看似寻常的行为&#xff0c;实则暗藏致命风险。普通手机在易燃易爆环境中可能成为“隐形炸弹”&#xff0c;而防爆手机却能安全护航。这两者看似相似&#xff0c;实则从底层基因到应用场景都存在着本质差异&#xf…...

C语言结构体的别名与创建结构体变量

这段代码是用C语言定义了一个链表节点的结构体&#xff0c;并通过typedef为相关类型创建了别名。下面分别解释Lnode和pNode&#xff1a; 1. Lnode Lnode是通过typedef为struct node定义的一个别名。struct node是一个结构体类型&#xff0c;表示一个链表节点。它的定义如下&a…...

在RTX5060Ti上进行Qwen3-4B的GRPO强化微调

导语 最近赶上618活动&#xff0c;将家里的RTX 4060显卡升级为了RTX 5060Ti 16GB版本&#xff0c;显存翻了一番&#xff0c;可以进行一些LLM微调实验了&#xff0c;本篇博客记录使用unsloth框架在RTX 5060Ti 16GB显卡上进行Qwen3-4B-Base模型的GRPO强化微调实验。 简介 GPU性…...

SQL进阶之旅 Day 7:视图与存储过程入门

【SQL进阶之旅 Day 7】视图与存储过程入门 在SQL开发中&#xff0c;视图&#xff08;View&#xff09;和存储过程&#xff08;Stored Procedure&#xff09;是两个非常重要的数据库对象。它们不仅可以简化复杂查询逻辑&#xff0c;还能提高代码复用性和安全性。本文将深入探讨…...

武汉火影数字VR大空间制作

VR大空间是一种利用空旷的物理空间&#xff0c;结合先进的虚拟现实技术&#xff0c;让用户能够在其中自由移动并深度体验虚拟世界的创新项目方式。 在科技飞速发展的当下&#xff0c;VR大空间正以其独特的魅力&#xff0c;成为科技与娱乐领域的耀眼新星&#xff0c;掀起了一股沉…...

Docker部署项目无法访问,登录超时完整排查攻略

项目背景&#xff1a;迁移前后端应用&#xff0c;prod环境要求保留443端口&#xff0c;开发环境37800端口&#xff0c;后端容器端口为8000&#xff0c;前端为80&#xff0c;fastAPI对外端口为41000 生产环境部署在VM01,开发环境部署在VM03&#xff0c;在VM01配置nginx转发 [r…...

(增强)基于sqlite、mysql、redis的消息存储

原文链接&#xff1a;&#xff08;增强&#xff09;基于sqlite、mysql、redis的消息存储 教程说明 说明&#xff1a;本教程将采用2025年5月20日正式的GA版&#xff0c;给出如下内容 核心功能模块的快速上手教程核心功能模块的源码级解读Spring ai alibaba增强的快速上手教程…...

Windows上用FFmpeg推流及拉流的流程概览

1. 视频采集与推流&#xff08;Windows FFmpeg&#xff09; 采集设备&#xff1a;Windows上的摄像头&#xff0c;比如“Integrated Camera”。 采集方式&#xff1a;FFmpeg通过 dshow 设备接口读取摄像头。 推流协议&#xff1a;你可以选择推到 RTMP 或 RTSP 服务器。 推流…...

MFC坦克大战游戏制作

MFC坦克大战游戏制作 前言 现在的游戏制作一般是easyx&#xff0c;有没有直接只用mfc框架的&#xff0c;笔者研究了一番&#xff0c;做出了一个雏形&#xff0c;下面把遇到的问题总结出来 一、MFC框架制作游戏 初步设想&#xff0c;MFC可以选用 对话框 或者 单文档 结构&…...

Kafka ACK机制详解:数据可靠性与性能的权衡之道

在分布式消息系统中&#xff0c;消息确认机制是保障数据可靠性的关键。Apache Kafka 通过 ACK&#xff08;Acknowledgment&#xff09;机制 实现了灵活的数据确认策略&#xff0c;允许用户在 数据可靠性 和 系统性能 之间进行权衡。本文将深入解析 Kafka ACK 机制的工作原理、配…...

VulnStack|红日靶场——红队评估四

信息收集及漏洞利用 扫描跟kali处在同一网段的设备&#xff0c;找出目标IP arp-scan -l 扫描目标端口 nmap -p- -n -O -A -Pn -v -sV 192.168.126.154 3个端口上有web服务&#xff0c;分别对应三个漏洞环境 &#xff1a;2001——Struts2、2002——Tomcat、2003——phpMyAd…...

数据库 | 时序数据库选型

选型目标 高性能与低延迟&#xff1a;满足高频率数据写入与即时查询的需求。资源效率&#xff1a;优化存储空间使用&#xff0c;减少计算资源消耗。可扩展架构&#xff1a;支持数据量增长带来的扩展需求&#xff0c;易于维护。社区活跃度&#xff1a;有活跃的开发者社区&#…...

网络拓扑如何跨网段访问

最近领导让研究下跟甲方合同里的&#xff0c;跨网段访问怎么实现&#xff0c;之前不都是运维网工干的活么&#xff0c;看来裁员裁到动脉上了碰到用人的时候找不到人了&#xff0c; 只能赶鸭子上架让我来搞 IP 网络中&#xff0c;不同网段之间的通信需要通过路由器&#xff0c;…...

CppCon 2014 学习第1天:An SQL library worthy of modern C++

sqlpp11 — 现代 C 应用值得拥有的 SQL 库 template<typename T> struct _member_t {T feature; };你提到的是一个 C 中的“成员模板&#xff08;Member Template&#xff09;”&#xff0c;我们来一步步理解&#xff1a; 基本代码分析&#xff1a; template<typena…...

【LLM相关知识点】 LLM关键技术简单拆解,以及常用应用框架整理(二)

【LLM相关知识点】 LLM关键技术简单拆解&#xff0c;以及常用应用框架整理&#xff08;二&#xff09; 文章目录 【LLM相关知识点】 LLM关键技术简单拆解&#xff0c;以及常用应用框架整理&#xff08;二&#xff09;一、市场调研&#xff1a;业界智能问答助手的标杆案例1、技术…...

数据分析与应用-----使用scikit-learn构建模型

目录 一、使用sklearn转换器处理数据 &#xff08;一&#xff09;、加载datasets模块中的数据集 &#xff08;二&#xff09;、将数据集划分为训练集和测试集 ​编辑 train_test_spli &#xff08;三&#xff09;、使用sklearn转换器进行数据预处理与降维 PCA 二、 构…...

003 flutter初始文件讲解(2)

1.书接上回 首先&#xff0c;我们先来看看昨天最后的代码及展示效果&#xff1a; import "package:flutter/material.dart";void main(){runApp(MaterialApp(home:Scaffold(appBar:AppBar(title:Text("The World")), body:Center(child:Text("Hello…...

Windows系统下 NVM 安装 Node.js 及版本切换实战指南

以下是 Windows 11 系统下使用 NVM 安装 Node.js 并实现版本自由切换的详细步骤&#xff1a; 一、安装 NVM&#xff08;Node Version Manager&#xff09; 1. 卸载已有 Node.js 如果已安装 Node.js&#xff0c;请先卸载&#xff1a; 控制面板 ➔ 程序与功能 ➔ 找到 Node.js…...

基于热力学熵增原理的EM-GAM

简介 简介:提出基于热力学熵增原理的EM-GAN,通过生成器熵最大化约束增强输出多样性。引入熵敏感激活函数与特征空间熵计算模块,在MNIST/CelebA等数据集上实现FID分数提升23.6%,有效缓解模式崩溃问题。 论文题目:Entropy-Maximized Generative Adversarial Network (EM-G…...

2025.05.28-华为暑期实习第一题-100分

📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 01. K小姐的网络信号优化方案 问题描述 K小姐在负责一个智慧城市项目,该项目需要在一条主干道上部署无线信号发射器。这条主干道有 n n...

鸿蒙OSUniApp滑动锁屏实战:打造流畅优雅的移动端解锁体验#三方框架 #Uniapp

UniApp滑动锁屏实战&#xff1a;打造流畅优雅的移动端解锁体验 引言 移动应用的安全性和用户体验是开发中不可忽视的重要环节。滑动锁屏作为一种直观、安全且用户友好的解锁方式&#xff0c;在移动应用中得到广泛应用。本文将深入探讨如何使用UniApp框架实现一个功能完备、动…...

数据库中 用一个值实现类似linux中的读 写执行以及理解安卓杂用的按位或运算

数据库定义了一个字段叫 allow, 4 读2 写 1 执行 如果是 7 就代表是可读可写 可执行 &#xff0c;如果是5 就是可读 可执行 &#xff0c; 那具体代码咋写呢 [Flags] public enum Permission {None 0,Execute 1,Write 2,Read 4 }// 假设你从数据库取到的 allow 值是一个整数…...

什么是数据驱动?以及我们应如何理解数据驱动?

在谈到企业数字化转型时&#xff0c;很多人都会说起“数据驱动”&#xff0c;比如“数据驱动运营”、“数据驱动业务”等等。 在大家言必称“数据驱动”的时代背景下&#xff0c;我相信很多人并未深究和思考“数据驱动”的真正含义&#xff0c;只是过过嘴瘾罢了。那么&#xff…...

opencv(C++) 图像滤波

文章目录 介绍使用低通滤波器对图像进行滤波工作原理均值滤波器(Mean Filter / Box Filter)高斯滤波器(Gaussian Filter)案例实现通过滤波实现图像的下采样工作原理实现案例插值像素值(Interpolating pixel values)双线性插值(Bilinear interpolation)双三次插值(Bicu…...