1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-26 15:30:04 +08:00
SpaceVim/docs/_posts/2018-09-19-use-vim-as-a-java-ide.md
2020-05-17 14:08:03 +08:00

186 lines
7.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: "使用 Vim 搭建 Java 开发环境"
categories: [tutorials_cn, blog_cn]
description: "如何使用 Vim 搭建 Java 的开发环境,自动补全、语法检查、代码格式化、交互式编程以及断点调试相关使用技巧"
permalink: /cn/:title/
lang: zh
type: article
comments: true
commentsID: "使用 Vim 搭建 Java 开发环境"
---
# [Blogs](../blog/) > 使用 Vim 搭建 Java 开发环境
这篇文章主要介绍如何使用 SpaceVim 搭建 Java 开发 Vim 环境,主要涉及到 `lang#java` 模块。
<!-- vim-markdown-toc GFM -->
- [启用模块](#启用模块)
- [语言服务器](#语言服务器)
- [代码补全](#代码补全)
- [语法树](#语法树)
- [重命名光标符号](#重命名光标符号)
- [光标符号文档查询](#光标符号文档查询)
- [语法检查](#语法检查)
- [导包](#导包)
- [跳转测试文件](#跳转测试文件)
- [编译运行](#编译运行)
- [代码格式化](#代码格式化)
- [交互式编程](#交互式编程)
<!-- vim-markdown-toc -->
### 启用模块
SpaceVim 初次安装时默认并未启用相关语言模块。首先需要启用
`lang#java` 模块, 通过快捷键 `SPC f v d` 打开配置文件,添加:
```toml
[[layers]]
name = "lang#java"
```
启用 `lang#java` 模块后,在打开 java 文件时,就可以使用语言专属快捷键,这些快捷键都是以 `SPC l` 为前缀的。
`lang#java` 模块主要采用插件 vim-javacomplete2该插件可以自动读取工程配置文件获取当前项目的 classpath
目前支持的项目包括 maven、gradle 以及 eclipse 下的配置文件。
### 语言服务器
若需要启动 Java 语言服务支持,可以启用 lsp 模块,以下配置示例使用 [eclipse.jdt.ls](http://ftp.yz.yamagata-u.ac.jp/pub/eclipse/jdtls/snapshots/jdt-language-server-latest.tar.gz),下载后并解压:
```toml
[[layers]]
name = "lsp"
filetypes = [
"java"
]
[layers.override_cmd]
java = [
"java",
"-Declipse.application=org.eclipse.jdt.ls.core.id1",
"-Dosgi.bundles.defaultStartLevel=4",
"-Declipse.product=org.eclipse.jdt.ls.core.product",
"-Dlog.protocol=true",
"-Dlog.level=NONE",
"-noverify",
"-Xmx1G",
"-jar",
"D:\\dev\\jdt-language-server-latest\\plugins\\org.eclipse.equinox.launcher_1.5.200.v20180922-1751.jar",
"-configuration",
"D:\\dev\\jdt-language-server-latest\\config_win",
"-data",
"C:\\Users\\Administrator\\.cache\\javalsp"
]
```
需要将配置中 `D:\dev\jdt-language-server-latest\plugins\org.eclipse.equinox.launcher_1.5.200.v20180922-1751.jar`
改为 org.eclipse.equinox.launcher jar 文件的实际路径。
根据当前系统,选择对应的配置文件:
- `config_win`, Windows 系统
- `config_mac`, MacOS 系统
- `config_linux`, Linux 系统
`-data` 选项指定语言服务器的运行绝对路径。这应该不同于用户项目文件的路径。
### 代码补全
vim-javacomplete2 为 java 项目提供了很好的代码补全功能,配合 autocomplete 模块,可以在编辑代码时实时补全代码,并且可以模糊匹配。
![code complete](https://user-images.githubusercontent.com/13142418/80611950-e36f1e00-8a6d-11ea-8800-8593402761d4.png)
### 语法树
默认的语法树插件是 tagbar快捷键为 `F2`。这一快捷键将会在左侧打开一个语法树侧栏,如下图所示:
![java outline](https://user-images.githubusercontent.com/13142418/80612099-13b6bc80-8a6e-11ea-99da-a4a656b8009e.png)
如果需要使用模糊搜索快速调到当前文件中的某个函数,首先需要载入一个模糊搜索的模块,比如 denite 模块:
```toml
[[layers]]
name = "denite"
```
之后使用快捷键 `Leader f o` 就可以打开模糊搜索窗口,效果图如下:
![java fuzzy outline](https://user-images.githubusercontent.com/13142418/80612410-86279c80-8a6e-11ea-884e-539781f0af36.gif)
### 重命名光标符号
当启用了 lsp 模块,并配置好 Java 语言服务器后,可以使用快捷键 `SPC l e` 对光标下的符号进行重命名:
![rename java symblo](https://user-images.githubusercontent.com/13142418/80612586-bcfdb280-8a6e-11ea-8b24-7809dc022417.gif)
### 光标符号文档查询
同样的,这一功能也依赖 lsp 模块,默认的快捷键为 `SPC l d` 或者 `K`
![javadoc](https://user-images.githubusercontent.com/13142418/80612801-0cdc7980-8a6f-11ea-82b5-62f7dec57138.gif)
### 语法检查
`checkers` 模块为 SpaceVim 提供了异步语法检查功能,该模块主要包括插件 [neomake](https://github.com/neomake/neomake)。
目前支持的项目包括 maven、gradle 以及 eclipse 下的配置文件。
![lint-java](https://user-images.githubusercontent.com/13142418/80613077-5f1d9a80-8a6f-11ea-8622-7bcea958f1a5.png)
从上图,我们可以看到,目前语法检查支持如下功能:
- 在底部分割窗口列出所有语法问题
- 在侧边使用标记符号标记错误信息
- 在状态了显示错误及警告数量
- 当光标所在位置存在错误,在光标的下一行展示错误细节,移动光标后,这个错误描述就会被清除,并不会影响代码内容
### 导包
在编辑 java 文件时,导包的操作主要有两种,一种是自动导包,一种是手动导包。自动导包主要是在选中某个补全的类后,自动导入该类。
手动导包的快捷键是 `<F4>`,可将光标移动到类名上,按下 F4 手动导入该包。会出现这样一种情况classpath 内有多个可选择的类,
此时会在屏幕下方弹出提示,选择相对应的类名即可。
![import class](https://user-images.githubusercontent.com/13142418/80613234-92f8c000-8a6f-11ea-8cb7-584ed3545cb7.png)
### 跳转测试文件
在编辑 java 源文件时,可以通过命令 `:A` 跳转到与之对应的测试文件,这一功能主要依赖 tpope 的 vim-project以 maven 项目为例,
需要在项目根目录添加配置文件 `.projections.json`,内容如下:
```json
{
"src/main/java/*.java": {"alternate": "src/test/java/{dirname}/Test{basename}.java"},
"src/test/java/**/Test*.java": {"alternate": "src/main/java/{}.java"}
}
```
基于这样的配置,就可以实现源文件和测试文件相互跳转了。
![jump-test](https://user-images.githubusercontent.com/13142418/80613408-d7845b80-8a6f-11ea-83cd-c44af9a12656.gif)
### 编译运行
主要基于 JavaUnite可以编译并运行当前类也可以执行某个指定的函数。`SPC l r c` 执行光标函数, `SPC l r m` 执行 main 函数。
![run-main](https://user-images.githubusercontent.com/13142418/80613620-19ad9d00-8a70-11ea-97e1-d8e4c0033536.gif)
### 代码格式化
基于 `format` 模块,可以使用 `SPC b f` 对当前代码进行格式化,`format` 模块主要包括插件 [neoformat](https://github.com/sbdchd/neoformat)。
该插件提供了格式化框架,对于 java 的支持,还需要安装 [uncrustify](http://astyle.sourceforge.net/) 或者 [astyle](http://astyle.sourceforge.net/)。
同时,你也可以使用谷歌的 [java formatter](https://github.com/google/google-java-format)。
![format-java](https://user-images.githubusercontent.com/13142418/80613869-5e393880-8a70-11ea-9fc7-3e5661af80cd.gif)
### 交互式编程
jdk9 引入了 `jshell`,让 java 的交互式编程成为了可能,在 SpaceVim 里,可以通过快捷键 `SPC l s i` 其同该功能。REPL 窗口打开后,
可以通过 `SPC l s l``SPC l s s` 等快捷键发送代码给 jshell目前支持发送当前行、选中内容及整个文件内容。
![repl-java](https://user-images.githubusercontent.com/13142418/80614311-e0c1f800-8a70-11ea-8930-9bdad411bbed.gif)