本文介绍如何通过 launch4j maven 插件的 `singleinstance` 配置项,确保打包后的 windows 可执行文件(.exe)在同一系统中仅允许一个实例运行,避免重复启动导致的资源冲突或逻辑异常。
Launch4j 是一款广泛使用的开源工具,可将 Java 应用程序(JAR 包)封装为 Window

在 Maven 项目中,只需在 launch4j-maven-plugin 的
com.github.akman launch4j-maven-plugin2.13.0 l4j-gui package launch4j gui ${project.build.directory}/${project.artifactId}-${project.version}.jar ${project.build.directory}/myapp.exe com.example.MyApp true
✅ 注意事项:
- singleInstance 仅在 Windows 平台生效(底层调用 Win32 CreateMutexW),Linux/macOS 下会被忽略;
- 启用后,第二次启动时进程将立即终止,不会进入 main() 方法——因此,若需向已有实例传递参数(如打开新文件),必须结合 JVM 启动参数(如 -Dlaunch4j.singleInstance=true)并在 Java 代码中监听 IPC 信号(推荐使用 JUnique 或 JNIWrapper 等第三方库);
- 若应用含 GUI,建议同时配置
true 防止控制台窗口闪退,并确保主窗口正确响应激活事件; - 测试时请关闭所有相关进程(包括后台残留的 Java 进程),避免互斥体未释放导致误判。
总之,








