news 2026/4/23 11:30:24

如何解决 Kotlin/Native 在 Windows 下 main 函数的 args 乱码?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何解决 Kotlin/Native 在 Windows 下 main 函数的 args 乱码?

之前在用 Kotlin/Native 写 codex-kkp 的时候遇到了一个问题:
当我尝试在 Windows 的命令行上向它的产物 exe 传递参数的时候,传入的中文参数会变成我们熟悉又陌生的乱码“锟斤拷”。

codex-kkp-cli.exe"分析代码"# 实际收到的参数变成了乱码

问题分析

那么为什么会这样呢?众所周知,“锟斤拷”系列的乱码通常是 GBK 和 UTF-8 之间的错误转码导致的。
而又众所周知,Windows 存在两套字符API:GBK 是 Windows 默认的中文系统编码(A 版本, ANSI),
UTF-16 则是内核的原生编码(W 版本, 宽、Unicode)。

参考文档:

  • Windows API 中的 Unicode
  • 代码页

而 Kotlin/Native mingwX64 平台 的 main 函数编译后会使用 ANSI 版本的API的入口点:

launcher.cpp#L72-L78
中的Konan_main函数:

extern "C" RUNTIME_EXPORT int Konan_main(int argc, const char** argv) { return Init_and_run_start(argc, argv, 1); }

和 StubIrDriver.kt#L225-L232
里面生成的 main 函数:

out("extern int Konan_main(int argc, char** argv);") out("") out("__attribute__((__used__))") out("int $entryPoint(int argc, char** argv) {") out(" return Konan_main(argc, argv);") out("}")

也就是:

extern int Konan_main(int argc, char** argv); int main(int argc, char** argv) { return Konan_main(argc, argv); }

它没有使用wmainwchar_t** argv,所以它使用的是 ANSI 的 API 而不是 Unicode 的那个。

这个问题在 YouTrack 上也有相关记载:

  • KT-82801: Kotlin/Native: Windows Non-ASCII command-line arguments garbled characters
  • KT-80201: K/N: Windows main(args) receives corrupted Unicode arguments

在 KT-80201 中,也有热心网友贴出了解决方案,这也是接下来要进行介绍的内容。

解决方案

如果你比较熟悉 Windows 的 API,那么应该很快就能想到该如何了解。但是我就不一样了,我对这类 native 相关的东西一窍不通(

OK 言归正传,由于 Kotlin 的main函数接收到的args已经是处于乱码状态的错误参数,因此我们不能直接使用这个args了,
而是要用 Windows 的 W 版本 API 来直接获取通过 UTF-16 编码的正确参数,以此绕过 ANSI 的入口点带来的错误结果。

那么怎么绕开呢?说难也不难,我们可以直接通过platform.windows.GetCommandLineW()来获取 UTF-16 的命令行参数。
完整代码参考如下:

fun getUnicodeArgs(): Array<String> = memScoped { // 获取原始的 UTF-16 命令行 val commandLine = GetCommandLineW() ?: return@memScoped emptyArray() // 解析命令行为参数数组 val argc = alloc<IntVar>() val argv = CommandLineToArgvW(commandLine.toKString(), argc.ptr) ?: return@memScoped emptyArray() try { val argCount = argc.value if (argCount <= 1) { // 只有程序名本身,没有其他参数 return@memScoped emptyArray() } // 转换参数(跳过程序名) Array(argCount - 1) { index -> argv[index + 1]?.toKStringFromUtf16() ?: "" } } finally { LocalFree(argv) } }

通过GetCommandLineW获取到W版本的命令行参数,然后通过CommandLineToArgvW将它们解析为参数数组,
随后将程序名之后的真正的 args 们通过toKStringFromUtf16转化为 Kotlin String 之后就得到了之最终我们需要的东西:
不乱码的 args 数组。

在一个 KMP 项目中,我们现在可以通过expect/actual来实现 mingwX64 平台下对参数的解析(至少我现在是这么做的):

// commonMain - 声明期望函数 internal expect fun resolveArgs(args: Array<String>): Array<String> // appleMain & linuxMain - 直接返回原参数(这些平台默认 UTF-8) internal actual fun resolveArgs(args: Array<String>): Array<String> = args // mingwMain - 使用 Windows Unicode API 重新获取参数 internal actual fun resolveArgs(args: Array<String>): Array<String> { // ... Unicode 处理逻辑 }

main方法中:

fun main(args: Array<String>) { val processedArgs = resolveArgs(args) // 接下来使用 processedArgs 而不是 args(你直接用 args 覆盖也行) }

总结

根据 KT-80201 的状态,至少目前来看官方还没有解决这个问题。
如果你比较关心这个问题的话,可以追踪下这个 issue,跟踪它的未来进展。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 1:25:19

EmotiVoice + WebRTC:构建实时情感语音通话系统的可行性分析

EmotiVoice WebRTC&#xff1a;构建实时情感语音通话系统的可行性分析 在虚拟助手开始“共情”&#xff0c;AI主播能用不同语气与观众互动的今天&#xff0c;语音交互早已不再满足于“把字念出来”。用户期待的是有情绪、有个性、像真人一样自然表达的声音。尤其是在远程陪伴…

作者头像 李华
网站建设 2026/4/23 11:28:51

EmotiVoice语音合成结果可解释性研究:理解情感生成逻辑

EmotiVoice语音合成结果可解释性研究&#xff1a;理解情感生成逻辑 在虚拟主播激情澎湃地讲述剧情、AI心理助手温柔安抚用户情绪的今天&#xff0c;我们早已不再满足于“能说话”的机器。真正打动人心的&#xff0c;是那些会生气、会惊喜、会低落的声音——它们让交互有了温度…

作者头像 李华
网站建设 2026/4/13 8:02:36

Knuff证书转换神器:3分钟学会APNS证书PEM格式导出

Knuff证书转换神器&#xff1a;3分钟学会APNS证书PEM格式导出 【免费下载链接】Knuff 项目地址: https://gitcode.com/gh_mirrors/knu/Knuff 还在为苹果推送服务的证书格式转换而头疼吗&#xff1f;作为iOS/macOS开发者&#xff0c;你是否经常需要在PKCS12格式和PEM格式…

作者头像 李华
网站建设 2026/4/23 11:30:16

Contest1110 - 河南工大2025新生周赛(8)-赛后总结

Contest1110 - 河南工大2025新生周赛&#xff08;8&#xff09;——命题人&#xff1a;庞贺航、高旭 - HAUTOJ A 签到题&#xff1f; 读题目&#xff0c;注意到α和β的值都为一&#xff0c;现要求二者相加的值&#xff08;经典线性求和&#xff09;&#xff0c;输出2即可 1…

作者头像 李华
网站建设 2026/4/20 3:29:31

EmotiVoice商业应用场景全景图:覆盖10大行业解决方案

EmotiVoice商业应用场景全景图&#xff1a;覆盖10大行业解决方案 在智能语音技术不断渗透日常生活的今天&#xff0c;用户早已不再满足于“能说话”的机器。当客服用毫无起伏的语调回应投诉、当有声书朗读像电子闹钟报时、当虚拟偶像直播依赖真人配音轮班上阵——这些场景背后&…

作者头像 李华
网站建设 2026/4/22 11:00:31

AI赋能智慧客服与人工客服融合系统企业级方案

文章目录 1. 项目概述与架构设计1.1 系统核心设计理念1.2 整体架构图1.3 技术栈选择 2. 环境搭建与项目初始化2.1 开发环境配置2.2 配置文件设计 3. 核心数据模型设计3.1 数据库模型定义3.2 数据库初始化脚本 4. AI核心组件实现4.1 NLP处理器&#xff08;意图识别与情感分析&am…

作者头像 李华