0

0

Sublime如何搭建一个轻量级的Java开发环境? (Build System与LSP)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-10 12:22:02

|

497人浏览过

|

来源于php中文网

原创

不能,但可凑合写、编译、运行简单java项目;需配置build system解决路径、类路径和主类识别,并搭配lsp+eclipse.jdt.ls实现基础语义功能。

sublime如何搭建一个轻量级的java开发环境? (build system与lsp)

Sublime Text 能不能当 Java IDE 用?

不能,但可以凑合写、编译、跑简单项目。Sublime 本身没有 Java 语义分析、跳转、重构能力,Build System 只负责调 javacjava,而 LSP(Language Server Protocol)插件能补一部分实时诊断和补全——前提是后端语言服务器(如 eclipse.jdt.ls)正常运行。别指望它替代 IntelliJ,但写算法题、小工具、课设 Demo 完全够用。

配置 Build System:让 Ctrl+B 编译并运行 .java 文件

关键不是写个 JSON,而是解决路径、类路径、主类识别这三件事。默认的 Java build system 不支持自动找 public static void main 所在类,也不处理依赖。

  • Tools → Build System → New Build System… 打开,粘贴以下内容(注意替换 JAVA_HOME 路径)
  • shell_cmd 必须用 cmd /c(Windows)或 sh -cmacOS/Linux),否则多条命令串不起来
  • 如果源文件在子包中(如 com.example.Hello),必须确保目录结构匹配,并在终端里 cd 到 src 根目录再运行 build(否则 javac 找不到包路径)
{
    "shell_cmd": "cmd /c "cd /d \"$file_path\" && javac -encoding UTF-8 $file_name && java $file_base_name"",
    "file_regex": "^(...*?):([0-9]*):?([0-9]*)",
    "selector": "source.java",
    "variants": [
        {
            "name": "Run with classpath",
            "shell_cmd": "cmd /c "cd /d \"$file_path\" && javac -encoding UTF-8 -cp .;$packages/JavaCp/lib/* $file_name && java -cp .;$packages/JavaCp/lib/* $file_base_name""
        }
    ]
}

保存为 JavaC.sublime-build,然后选中它。注意:$packages/JavaCp/lib/* 是你手动建的 lib 目录,放 .jar 依赖;Windows 用分号 ;,macOS/Linux 用冒号 : 分隔 classpath。

启用 LSP + eclipse.jdt.ls:获得基础补全与报错提示

Sublime 的 LSP 插件只是协议桥接器,真正干活的是外部 Java 语言服务器 eclipse.jdt.ls。它体积大(300MB+)、启动慢、首次索引卡顿,但比纯 Build System 强在能识别 import、跳转定义、标出未闭合括号等。

LuckyCola工具库
LuckyCola工具库

LuckyCola工具库是您工作学习的智能助手,提供一系列AI驱动的工具,旨在为您的生活带来便利与高效。

下载

立即学习Java免费学习笔记(深入)”;

  • 先装好 LSP 插件(通过 Package Control),再装 LSP-jdtls(推荐)或手动配置 LSP 设置
  • eclipse.jdt.ls 需要 Java 17 运行时,不是 JDK 8 —— 即使你项目用 JDK 8 编译,服务器本身必须用 JDK 17+
  • LSP.sublime-settings 里加配置,重点是 initializationOptions 中的 sharedIndexLocation 要指向空目录,否则首次启动失败
  • 项目根目录下必须有 mvnwpom.xml,或手动建 .project + .classpath,否则 jdt.ls 不识别为 Java 项目,只当普通文本

配置片段示例(放在 "clients": {"jdtls": {…}} 内):

"command": ["java", "-Declipse.application=org.eclipse.jdt.ls.core.id1", "-Dosgi.bundles.defaultStartLevel=4", "-Dosgi.configuration.cascaded=true", "-Dlog.level=INFO", "-Xms1g", "-Xmx2g", "-jar", "/path/to/jdt-language-server/plugins/org.eclipse.equinox.launcher_*.jar", "-configuration", "/path/to/jdt-config", "-data", "/path/to/workspace"],
"enabled": true,
"initializationOptions": {
    "bundles": [],
    "settings": {"java.configuration.updateBuildConfiguration": "interactive"},
    "sharedIndexLocation": "/tmp/jdtls-shared-index"
}

常见失效场景和绕过方法

Build System 和 LSP 在 Sublime 里是两套逻辑,经常一个起作用另一个挂掉。最常遇到的问题不是配置错,而是环境没对齐。

  • Error: Could not find or load main class:多半是 java 命令执行时不在源码根目录,或类名没写对(比如文件叫 A.java 但类是 public class B
  • LSP 显示 “Server crashed”:检查 java -version 输出是否 ≥ 17;删掉 ~/.config/jdtls(Linux/macOS)或 %USERPROFILE%.jdtls(Windows)重置缓存
  • 补全没反应:确认当前文件已保存(.java 后缀)、语法高亮是 Java(右下角显示 Java)、且光标在类内部而非注释里
  • 中文乱码:Build System 加 -encoding UTF-8;LSP 的 settings.json 里加 "java.configuration.runtimes": [{ "name": "JavaSE-17", "path": "/path/to/jdk-17" }]

真要长期写 Java,还是尽早切到 VS Code(内置 JDT LS 支持更好)或 IntelliJ;Sublime 的优势只在“开得快、占内存少、改完就跑”,适合临时查问题、刷 OJ、看别人代码——别让它承担本不属于它的职责。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

328

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

eclipse教程
eclipse教程

php中文网为大家带来eclipse教程合集,eclipse是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。php中文网还为大家带来eclipse的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

193

2023.06.14

eclipse怎么设置中文
eclipse怎么设置中文

eclipse设置中文的方法:除了设置界面为中文外,你还可以为Eclipse添加中文插件,以便更好地支持中文编程。例如,你可以安装EBNF插件来支持中文变量名,或安装Chinese Helper来提供中文帮助文档。本专题为大家提供eclipse设置中文相关的各种文章、以及下载和课程。

804

2023.07.24

c语言编程软件有哪些
c语言编程软件有哪些

c语言编程软件有GCC、Clang、Microsoft Visual Studio、Eclipse、NetBeans、Dev-C++、Code::Blocks、KDevelop、Sublime Text和Atom。更多关于c语言编程软件的问题详情请看本专题的文章。php中文网欢迎大家前来学习。

620

2023.11.02

Eclipse版本号有哪些区别
Eclipse版本号有哪些区别

区别:1、Eclipse 3.x系列:Eclipse的早期版本,包括3.0、3.1、3.2等;2、Eclipse 4.x系列:Eclipse的最新版本,包括4.0、4.1、4.2等;3、Eclipse IDE for Java Developers等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2024.02.23

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

3

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.1万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号