IDE

Idea使用

Posted by Wh0ami-hy on January 12, 2023

1. IDEA版本

建议使用专业版,且使用大版本的最后一个更新版,如 2022.3.x

下载zip格式的,解压即用无需安装

2. 初始化配置

将项目都关闭后,在idea的初始界面进行配置,这样是全局的配置,对每个项目都生效的

2.1. 强制配置

  • IDEA中的text file encoding设置为UTF- 8,with no bom,transparent to ascii 都勾选
  • IDEA中文件的换行符使用Unix格式,不要使用Windows格式
  • IDEA设置tab为 4 个空格,请勿勾选Use tab character

2.2. 建议配置

  • 字体设置Fira Code
  • 方法间加横线editor->general->appearance-> 选show method separators
  • 代码提示不区分大小写editor->general->code completion-> 选all letters
  • 自动导包功能及相关优化功能Settings -> Editor -> General -> Auto Import

Add UNambiguous imports on the fly选项:IDEA 将在书写代码的时候自动帮我们导入需要用到的包。但是对于那些同名的包,还是需要手动 Alt + Enter 进行导入

Optimize imports on the fly选项:IDEA 将在我们书写代码的时候自动帮我们优化导入的包,比如自动去掉一些没有用到的包

  • CTRL + 滑动滚轮 调整窗口显示大小

Settings -> Editor -> General -> Change font size (Zoom) with Ctrl+Mouse wheel

  • 代码编辑区显示行号

Settings -> Editor -> General -> Appearance 勾选 Show Line Numbers

3. 快捷键

3.1. 模板相关

idea里面提供了两套模板Live Templates和Postfix Completion。Live Templates 可以自定义,而 Postfix Completion 不可以。Postfix Completion的功能:快速生成语句,如 sout生成System.out.println()

3.1.1. Postfix Completion

具体可查看editor->general->Postfix Completion

3.1.2. File and Code Template

文件代码模板

Settings -> Editor -> File and Code Template

当你选择某个文件生成时,就会按照这里面的模板生成指定的代码文件

3.1.3. Live Templates

定制代码模板

Settings -> Editor -> Live Templates 可以按照自己的使用习惯来定制相关的代码模板

类注释模板

/**
 * @ClassName ${NAME}
 * @Description 功能描述
 * @Author ${USER}
 * @Date ${DATE} ${TIME}
 * @Version 1.0.0
 */

方法注释模板

/**
 * @description 功能描述
 * @author ${USER}
 * @date $time$ $date$
 * @param $param$
 * @return $return$
 **/

变量配置

作者:user()
类名:className()
日期:date("yyyy/MM/dd")
时间:time()

方法参数:groovyScript("def result=''; def params=\"${_1}\".replaceAll('[\\\\[|\\\\]|\\\\s]', '').split(',').toList(); for(i = 0; i < params.size(); i++) {result+=' * @param ' + params[i] + ((i < params.size() - 1) ? '\\n' : '')}; return result", methodParameters())

返回值:groovyScript("return \"${_1}\" == 'void' ? null : '\\r\\n * @return ' + \"${_1}\"", methodReturnType())

异常:expressionType(Expression)

3.2. 其他操作

快速生成标准类

右键 generate --> getter、setter

获取完整包路径

项目结构中的文件处,右键 copypath

查看pom.xml依赖树

pom.xml中右键diagrams-->show dependency

生成JavaDoc文档

打开idea上方工具(Tools) 生成JavaDoc文档(Generate JavaDoc...)

注意 设置编码,防止中文乱码

生成构造方法

右键 generate --> constructor

重命名变量(可以一键全部替换)shift+alt+r

Ctrl + 鼠标滚轮设置字体大小,按住Ctrl + Shift + A调出搜索框,调出搜索框后搜索关键词 mouse ,设置鼠标相关设置,选择Change font size with Ctrl + Mouse Wheel

3.3. 查找

快捷键 介绍
Ctrl + F 在当前文件进行文本查找
Ctrl + R 在当前文件进行文本替换
Shift + Ctrl + F 在项目进行文本查找
Shift + Ctrl + R 在项目进行文本替换
Shift + Shift 快速搜索
Ctrl + b 查看方法对应的源代码

3.4. 跳转切换

快捷键 介绍
Ctrl + Tab 切换文件
Ctrl + Alt + ←/→ 跳转历史光标所在处
Alt + ←/→ 方向键 切换子tab
Ctrl + G go to(跳转指定行号)

3.5. 编码相关

快捷键 介绍
Ctrl + / 生成注释
Ctrl + Y 删除整行
Ctrl + Z 、Ctrl + Shift + Z 后悔药,撤销、取消撤销
Alt + enter IntelliJ IDEA 根据光标所在问题,提供快速修复选择,光标放在的位置不同提示的结果也不同
Alt + ↑/↓ 方法快速跳转
F2 跳转到下一个高亮错误 或 警告位置
Alt + Insert 代码自动生成,如生成对象的 set / get 方法,构造函数,toString() 等
Ctrl + Shift+Alt + L 格式化代码
Shift + F6 快速修改方法名、变量名、文件名、类名等
Ctrl + F6 快速修改方法签名
Ctrl + shift + u 字母转大写或小写

3.6. 代码阅读相关

快捷键 介绍
Ctrl + P 方法参数提示显示
Ctrl + Shift + i 就可以在当前类里再弹出一个窗口出来
Alt + F7 可以列出变量在哪些地方被使用了
光标在子类接口名,Ctrl + u 跳到父类接口
Ctrl + (Alt) + B 跳转方法定义/实现
Ctrl + H 类的层级关系
Ctrl + F12 Show Members 类成员快速显示

4. 插件推荐

CheckStyle-IDEA:追求代码规范的话,可以安装这个插件,它会提醒你注意无用导入、注释、语法错误、代码冗余等等

GitToolBox:它能直接提示你远程版本库里有多少文件更新,你有多少文件没有提交到版本库,甚至可以显示上一次提交的时间和版本更新者

Rainbow Brackets:彩虹括号,代码层级变得更加清晰

CodeGlance:代码微型地图

jclasslib:一款IDEA字节码查看神器

SequenceDiagram:一键可以生成时序图

EasyCode:可以直接对数据的表生成 entity、controller、service、dao、mapper 无需任何编码

maven helper:maven 依赖管理助手 ,解析maven pom结构,分析冲突

MyBatis Log Plugin:把 Mybatis 输出的sql日志还原成完整的sql语句,看起来更直观

String Manipulation:String相关辅助简化,搭配 CTRL+W 、ALT+J等文本选择快捷键使用

Visual Studio Code Dark Plus Theme:一款VSCode风格的主题

Background Image Plus: 背景图片

Statistic:可以非常直观地看到你的项目中所有类型的文件的信息比如数量、大小

Save Actions:可以帮助我们在保存文件的时候:优化导入;格式化代码

Free MyBatis tool

  • 生成mapper xml文件
  • 快速从代码跳转到mapper及从mapper返回代码
  • mybatis自动补全及语法错误提示
  • 集成mybatis generator gui界面

GsonFormatPlus:根据JSONObject格式的字符串,自动生成实体类参数

.ignore:这个插件方便我们在使用版本管理时对一些不想要上传的文件进行管理

easy Javadoc:快速生成类、方法、字段 的注释

Squaretest:自动生成单元测试代码,在选中类右键Generate -> Generate Test 后,不光能生成测试类和方法,甚至连Mockito 数据、方法和 Assertions 等都写好了,只需要自己改一改即可。

diffblue:单元测试生成插件

arthas idea: arthas 命令生成插件

5. IDEA中使用Git

在idea中使用git推送代码每次都要输入用户名和密码的解决办法

方法一:

在IP前面增加:用户名:密码@,例如我git用户名为:abc,密码为:123456,git仓库的地址为:http://127.0.0.1/project/helloWord.git,修改后的地址变成http://abc:123456@127.0.0.1/project/helloWord.git

方法二:

Appearance & Behavior > System Settings > Passwords 是否允许保存凭据

克隆、提交、推送、分支、冲突解决、历史查看、版本回退、版本对比

在IEDA里配置git执行程序的路径

【File】→ 【Settings】→ 【Vwesion Control】→ 【Git】,选择git可执行文件的路径(正确配置的情况下,点击Test会弹出git版本的提示)

使用IDEA中的Git工具从远程仓库克隆项目

打开IDEA,选择菜单上的 VCS(版本控制工具),选择【Checkout from Version Control】→【Git】

添加文件到暂存区

我们在项目里每添加一个文件,IDEA就会询问我们是否将文件添加到Git,选择【Add】将文件添加进git暂存区,此时git就可以对其文件进行追踪

提交到本地仓库

完成代码的开发后,需要将修改和添加的代码或文件提交到本地仓库上(文件已添加至暂存区,受git追踪),选择【VCS】→ 【Commit】

推送到远程仓库

把代码推送到远程服务器上,点击项目右键 →【Git】→【 Repositry 】→【Push】

分支开发(重点掌握)

假如,现在项目开发完成,需发布1.0版本,然后添加一个1.0的分支

  • 打开git分支的面板,点击【New Branch】
  • 输入分支名称,点击【OK】,创建了1.0的分支
  • 然后切换回主干分支master,进行2.0版本的开发

分支合并

  • 在1.0分支上完成BUG修改后,将主分支(master分支)与1.0分支进行合并。需要先切换到master分支,然后进行操作
  • 选择合并的分支(remote/orgin/1.0-提交到远程服务器上的1.0版本),填写合并的消息,点击【Merge】
  • 合并后,就把 master分支推上服务器。然后再从 mater 中创建2.0分支,那么 master 就是3.0版本了

冲突解决

冲突的场景

  • 多个分支合并的时候
  • 在一个分支上拉取或推送远程文件时

提交历史记录查看

查看文件或项目提交的历史记录:点击文件右键菜单 → 【Git】→ 【Show History】

回退上一个版本

打开文件的历史提交记录(在上边的第10点),选择回退的版本 → 【Get】

6. IDEA连接GitLab

通过token的方式连接:启用IDEA中的GitLab插件

通过账号密码的方式连接:禁用IDEA中的GitLab插件

7. Debug(重点)

重点:在断点调试过程中,是运行状态,对象是运行类型,不是编译类型

7.1. 什么是断点调试

断点调试是指在程序的某一行设置一个断点,调试时,程序运行到这一行就会停住,然后你可以一步一步往下调试,调试过程中可以看各个变量当前的值,出错的话,调试到出错的代码行即显示错误,停下。进行分析从而找到这个Bug

7.2. 断点调试快捷键

idea支持debug过程中动态设置断点

  • F7:跳入方法内(alt + shift + F7 强制进入JDK源码)
  • F8:逐行执行代码
  • shift + F8:跳出方法
  • F9:执行到下一个断点

7.3. 多线程调试设置

idea的断点有不同的模式,只有当Thread模式下才能调试多线程,设置方式如下:

1、在断点上右键 2、选择Thread,然后点Done(建议选择Thread后点击make default把此模式设置为默认模式)

8. 代码风格规范化最佳实践

8.1. 代码规范性检查

关闭实时检测 setting——>editor——>Inspections——>checkstyle

代码规范性检查(按照阿里巴巴规范要求),搭配checkstyle插件使用

精简版(推荐)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE module PUBLIC
    "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
    "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
<module name="Checker">
    <!-- 文件级别的检查 -->
    <module name="NewlineAtEndOfFile"/>
    <module name="FileLength">
        <property name="max" value="1500"/>
    </module>
    <!-- 将 LineLength 移到这里,直接放在 Checker 下 -->
    <module name="LineLength">
        <property name="max" value="140"/>
    </module>

    <!-- TreeWalker 用于基于 AST 的检查 -->
    <module name="TreeWalker">
        <!-- 导入检查 -->
        <module name="IllegalImport"/>
        <module name="RedundantImport"/>
        <module name="UnusedImports"/>

        <!-- Javadoc 检查 -->
        <module name="JavadocType">
            <property name="allowUnknownTags" value="true"/>
            <message key="javadoc.missing" value="类注释:缺少Javadoc注释。"/>
        </module>

        <!-- 命名检查 -->
        <module name="LocalFinalVariableName"/>
        <module name="LocalVariableName"/>
        <module name="PackageName">
            <property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$"/>
            <message key="name.invalidPattern" value="包名 ''{0}'' 要符合 ''{1}''格式."/>
        </module>
        <module name="StaticVariableName"/>
        <module name="TypeName">
            <property name="severity" value="warning"/>
            <message key="name.invalidPattern" value="名称 ''{0}'' 要符合 ''{1}''格式."/>
        </module>
        <module name="MemberName"/>
        <module name="MethodName"/>
        <module name="ParameterName"/>
        <module name="ConstantName"/>

        <!-- 定义检查 -->
        <module name="ArrayTypeStyle"/>
        <module name="UpperEll"/>

        <!-- 其他长度检查(这些放在 TreeWalker 下是正确的) -->
        <module name="MethodLength">
            <property name="tokens" value="METHOD_DEF"/>
            <property name="max" value="50"/>
        </module>
        <module name="ParameterNumber">
            <property name="max" value="5"/>
            <property name="ignoreOverriddenMethods" value="true"/>
            <property name="tokens" value="METHOD_DEF"/>
        </module>

        <!-- 空格检查 -->
        <module name="MethodParamPad"/>
        <module name="TypecastParenPad"/>
        <module name="NoWhitespaceAfter"/>
        <module name="NoWhitespaceBefore"/>
        <module name="OperatorWrap"/>
        <module name="ParenPad"/>
        <module name="WhitespaceAfter"/>
        <module name="WhitespaceAround"/>

        <!-- 修饰符检查 -->
        <module name="ModifierOrder"/>
        <module name="RedundantModifier"/>

        <!-- 代码块检查 -->
        <module name="AvoidNestedBlocks"/>
        <module name="EmptyBlock"/>
        <module name="LeftCurly"/>
        <module name="NeedBraces"/>
        <module name="RightCurly"/>

        <!-- 代码检查 -->
        <module name="EmptyStatement"/>
        <module name="EqualsHashCode"/>
        <module name="HiddenField">
            <property name="tokens" value="VARIABLE_DEF"/>
        </module>
        <module name="InnerAssignment"/>
        <module name="MissingSwitchDefault"/>
        <module name="SimplifyBooleanExpression"/>
        <module name="SimplifyBooleanReturn"/>

        <!-- 类设计检查 -->
        <module name="FinalClass"/>
        <module name="InterfaceIsType"/>
        <module name="VisibilityModifier">
            <property name="packageAllowed" value="true"/>
            <property name="protectedAllowed" value="true"/>
        </module>

        <!-- 语法检查 -->
        <module name="StringLiteralEquality"/>
        <module name="NestedForDepth">
            <property name="max" value="2"/>
        </module>
        <module name="NestedIfDepth">
            <property name="max" value="3"/>
        </module>
        <module name="UncommentedMain">
            <property name="excludedClasses" value=".*[Application,Test]$"/>
        </module>
        <module name="Regexp">
            <property name="format" value="System\.out\.println"/>
            <property name="illegalPattern" value="true"/>
        </module>
        <module name="ReturnCount">
            <property name="max" value="3"/>
        </module>
        <module name="NestedTryDepth">
            <property name="max" value="3"/>
        </module>
        <module name="SuperClone"/>
        <module name="SuperFinalize"/>
    </module>
</module>

完整版

<?xml version="1.0"?>
<!DOCTYPE module PUBLIC
    "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
    "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">

<module name="Checker">

    <!-- 检查文件是否以一个空行结束 -->
    <module name="NewlineAtEndOfFile"/>

    <!-- 文件长度不超过1500行 -->
    <module name="FileLength">
        <property name="max" value="1500"/>
     </module>

    <!-- 每个java文件一个语法树 -->
    <module name="TreeWalker">
        <!-- import检查-->
        <!-- 避免使用* -->
        <module name="AvoidStarImport">
            <property name="excludes" value="java.io,java.net,java.lang.Math"/>
            <!-- 实例;import java.util.*;.-->
            <property name="allowClassImports" value="false"/>
            <!-- 实例 ;import static org.junit.Assert.*;-->
            <property name="allowStaticMemberImports" value="true"/>
        </module>
        <!-- 检查是否从非法的包中导入了类 -->
        <module name="IllegalImport"/>
        <!-- 检查是否导入了多余的包 -->
        <module name="RedundantImport"/>
        <!-- 没用的import检查,比如:1.没有被用到2.重复的3.import java.lang的4.import 与该类在同一个package的 -->   
        <module name="UnusedImports" />


        <!-- 注释检查 -->
        <!-- 检查方法和构造函数的javadoc -->
        <module name="JavadocType">
            <property name="allowUnknownTags" value="true"/>
            <message key="javadoc.missing" value="类注释:缺少Javadoc注释。"/>
        </module>
        <module name="JavadocMethod">
            <property name="tokens" value="METHOD_DEF" />
            <!--允许get set 方法没有注释-->
            <property name="allowMissingPropertyJavadoc" value="true"/>
            <message key="javadoc.missing" value="方法注释:缺少Javadoc注释。"/>
        </module>

        <!-- 命名检查 -->
        <!-- 局部的final变量,包括catch中的参数的检查 -->
        <module name="LocalFinalVariableName" />
        <!-- 局部的非final型的变量,包括catch中的参数的检查 -->
        <module name="LocalVariableName" />
        <!-- 包名的检查(只允许小写字母),默认^[a-z]+(\.[a-zA-Z_][a-zA-Z_0-9_]*)*$ -->
        <module name="PackageName">
            <property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$" />
            <message key="name.invalidPattern" value="包名 ''{0}'' 要符合 ''{1}''格式."/>
        </module>
        <!-- 仅仅是static型的变量(不包括static final型)的检查 -->
        <module name="StaticVariableName" />
        <!-- Class或Interface名检查,默认^[A-Z][a-zA-Z0-9]*$-->
        <module name="TypeName">
             <property name="severity" value="warning"/>
             <message key="name.invalidPattern" value="名称 ''{0}'' 要符合 ''{1}''格式."/>
        </module>
        <!-- 非static型变量的检查 -->
        <module name="MemberName" />
        <!-- 方法名的检查 -->
        <module name="MethodName" />
        <!-- 方法的参数名 -->
        <module name="ParameterName " />
        <!-- 常量名的检查(只允许大写),默认^[A-Z][A-Z0-9]*(_[A-Z0-9]+)*$ -->
        <module name="ConstantName" />

        <!-- 定义检查 -->
        <!-- 检查数组类型定义的样式 -->
        <module name="ArrayTypeStyle"/>
        <!-- 检查long型定义是否有大写的“L” -->
        <module name="UpperEll"/>

        <!-- 长度检查 -->
        <!-- 每行不超过120个字符 -->
        <module name="LineLength">
            <property name="max" value="120" />
        </module>
        <!-- 方法不超过50行 -->
        <module name="MethodLength">
            <property name="tokens" value="METHOD_DEF" />
            <property name="max" value="50" />
        </module>
        <!-- 方法的参数个数不超过5个。 并且不对构造方法进行检查-->
        <module name="ParameterNumber">
            <property name="max" value="5" />
            <property name="ignoreOverriddenMethods" value="true"/>
            <property name="tokens" value="METHOD_DEF" />
        </module>

        <!-- 空格检查-->
        <!-- 方法名后跟左圆括号"(" -->
        <module name="MethodParamPad" />
        <!-- 在类型转换时,不允许左圆括号右边有空格,也不允许与右圆括号左边有空格 -->
        <module name="TypecastParenPad" />
        <!-- 检查在某个特定关键字之后应保留空格 -->
        <module name="NoWhitespaceAfter"/>
        <!-- 检查在某个特定关键字之前应保留空格 -->
        <module name="NoWhitespaceBefore"/>
        <!-- 操作符换行策略检查 -->
        <module name="OperatorWrap"/>
        <!-- 圆括号空白 -->
        <module name="ParenPad"/>
        <!-- 检查分隔符是否在空白之后 -->
        <module name="WhitespaceAfter"/>
        <!-- 检查分隔符周围是否有空白 -->
        <module name="WhitespaceAround"/>

        <!-- 修饰符检查 -->
        <!-- 检查修饰符的顺序是否遵照java语言规范,默认public、protected、private、abstract、static、final、transient、volatile、synchronized、native、strictfp -->
        <module name="ModifierOrder"/>
        <!-- 检查接口和annotation中是否有多余修饰符,如接口方法不必使用public -->
        <module name="RedundantModifier"/>

        <!-- 代码块检查 -->
        <!-- 检查是否有嵌套代码块 -->
        <module name="AvoidNestedBlocks"/>
        <!-- 检查是否有空代码块 -->
        <module name="EmptyBlock"/>
        <!-- 检查左大括号位置 -->
        <module name="LeftCurly"/>
        <!-- 检查代码块是否缺失{} -->
        <module name="NeedBraces"/>
        <!-- 检查右大括号位置 -->
        <module name="RightCurly"/>

        <!-- 代码检查 -->
        <!-- 检查空的代码段 -->
        <module name="EmptyStatement"/>
        <!-- 检查在重写了equals方法后是否重写了hashCode方法 -->
        <module name="EqualsHashCode"/>
        <!-- 检查局部变量或参数是否隐藏了类中的变量 -->
        <module name="HiddenField">
            <property name="tokens" value="VARIABLE_DEF"/>
        </module>
        <!-- 检查是否使用工厂方法实例化 -->
        <module name="IllegalInstantiation"/>
        <!-- 检查子表达式中是否有赋值操作 -->
        <module name="InnerAssignment"/>
        <!-- 检查是否有"魔术"数字 -->
        <module name="MagicNumber">
           <property name="ignoreNumbers" value="0, 1"/>
           <property name="ignoreAnnotation" value="true"/>
       </module>
        <!-- 检查switch语句是否有default -->
        <module name="MissingSwitchDefault"/>
        <!-- 检查是否有过度复杂的布尔表达式 -->
        <module name="SimplifyBooleanExpression"/>
        <!-- 检查是否有过于复杂的布尔返回代码段 -->
        <module name="SimplifyBooleanReturn"/>

        <!-- 类设计检查 -->
        <!-- 检查类是否为扩展设计l -->
        <!-- 检查只有private构造函数的类是否声明为final -->
        <module name="FinalClass"/>
        <!-- 检查工具类是否有putblic的构造器 -->
        <module name="HideUtilityClassConstructor"/>
        <!-- 检查接口是否仅定义类型 -->
        <module name="InterfaceIsType"/>
        <!-- 检查类成员的可见度 检查类成员的可见性。只有static final 成员是public的 
        除非在本检查的protectedAllowed和packagedAllowed属性中进行了设置-->
        <module name="VisibilityModifier">
            <property name="packageAllowed" value="true"/>
            <property name="protectedAllowed" value="true"/>
        </module>

        <!-- 语法 -->
        <!-- String的比较不能用!= 和 == -->
        <module name="StringLiteralEquality"/>
        <!-- 限制for循环最多嵌套2层 -->
        <module name="NestedForDepth">
            <property name="max" value="2"/>
        </module>
        <!-- if最多嵌套3层 -->
        <module name="NestedIfDepth">
            <property name="max" value="3"/>
        </module>
        <!-- 检查未被注释的main方法,排除以Appllication结尾命名的类 -->
        <module name="UncommentedMain">
            <property name="excludedClasses" value=".*Application$"/>
        </module>
        <!-- 禁止使用System.out.println -->
        <module name="Regexp">
            <property name="format" value="System\.out\.println"/>
            <property name="illegalPattern" value="true"/>
        </module>
        <!-- return个数 3个-->
        <module name="ReturnCount">
            <property name="max" value="3"/>
        </module>
        <!--try catch 异常处理数量 3-->
        <module name="NestedTryDepth ">
            <property name="max" value="3"/>
        </module>
        <!-- clone方法必须调用了super.clone() -->
        <module name="SuperClone" />
        <!-- finalize 必须调用了super.finalize() -->
        <module name="SuperFinalize" />


    </module>
</module>

8.2. 代码格式化

IntelliJ IDEA 默认内置了对 EditorConfig 的支持。只要项目中存在 .editorconfig 文件,IDEA 会自动读取并应用其中的规则。无需额外安装插件。

开启 File > Settings > Editor > Code Style > Enable EditorConfig support

开启 File > Settings > Tools > Action on Save > Reformat code

如果有冲突(比如 IDEA 的代码风格设置与 .editorconfig 不一致),EditorConfig 的优先级通常更高

和上面代码规范化搭配的代码格式化.editorconfig配置文件

# EditorConfig is awesome: https://EditorConfig.org

# 应用于所有文件
root = true

[*]
charset = utf-8
end_of_line = lf
insert_final_newline = true  # 对应 NewlineAtEndOfFile
max_line_length = 140        # 对应 LineLength 的 max=140

# Java 文件特定的格式规则
[*.java]
# 缩进和空格规则(从 WhitespaceAround, NoWhitespaceAfter 等推导)
ij_java_space_after_comma = true              # WhitespaceAfter 分隔符后空格
ij_java_space_before_comma = false            # NoWhitespaceBefore 分隔符前无空格
ij_java_space_after_semicolon = true          # WhitespaceAfter 分号后空格
ij_java_space_before_semicolon = false        # NoWhitespaceBefore 分号前无空格
ij_java_space_inside_array_initializer_braces = true  # ArrayTypeStyle 和 WhitespaceAround 的推导
ij_java_space_before_array_initializer_left_brace = true
ij_java_space_after_operator_sign = true      # OperatorWrap 和 WhitespaceAround
ij_java_space_before_operator_sign = true     # OperatorWrap 和 WhitespaceAround
ij_java_space_within_parentheses = false      # ParenPad 圆括号内无空格
ij_java_space_after_type_cast = false         # TypecastParenPad 类型转换括号后无空格
ij_java_space_before_type_cast_left_parenthesis = false  # TypecastParenPad 类型转换括号前无空格
ij_java_space_after_method_call_name = false  # MethodParamPad 方法名后直接跟括号
ij_java_space_before_method_call_parentheses = false  # MethodParamPad 方法调用括号前无空格

# 大括号位置(LeftCurly 和 RightCurly 的推导)
ij_java_brace_style = end_of_line             # 大括号放在行尾,与 LeftCurly 默认行为一致
ij_java_do_not_indent_top_level_class_members = false

# 操作符换行(OperatorWrap)
ij_java_wrap_long_lines = true                # 操作符换行策略,默认允许换行

9. 常见问题

9.1. 当关闭IDEA时,提示“Closing project”

菜单 -> Help -> Find Action -> 输入“Registry” -> 在提示结果点击“Registry..”

去掉“ide.await.scope.completion”的勾选

9.2. maven项目没被识别

找到项目中的pom.xml,右键,选中Add as Maven Project 即可


本站总访问量