【方向盘】使用IDEA的60+个快捷键分享给你,权为了提效(IDEA导航篇)

2022年1月31日 316点热度 0人点赞 0条评论

扔掉鼠标,提高效率。本文已被https://yourbatman.cn收录;女娲Knife-Initializr工程可公开访问啦;程序员专用网盘https://wangpan.yourbatman.cn;技术专栏源代码大本营:https://github.com/yourbatman/tech-column-learning;公号后台回复“专栏列表”获取全部小而美的原创技术专栏

你好,我是方向盘(YourBatman)。笔者的公号是保留地,只分享原创,不转载、不发商务广告!

✍前言

春节快乐,阖家幸福! 今天,你能阅读完这篇技术文吗?

上篇文章(【方向盘】使用IDEA的60+个快捷键分享给你,权为了提效(操作系统、终端篇))向jar人们介绍了笔者在操作系统、终端层面经常使用的一些快捷键,本文继续,上主菜:IntelliJ IDEA快捷键。

在Java开发者中,一直存在着很多鄙视链。如(前者bs后者):

  • IntelliJ IDEA → Eclipse → NetBeans
  • Unix → Linux → Mac OS→ Windows → DOS
  • Emacs → Vim → Sublime → Word → Power Point

就笔者自己来讲,算是一个IDEA快捷键重度依赖患者,一个在IDEA里不使用快捷键,几乎没法工作的选手。

各行各业从业人员都有自己吃饭的“饭碗”,对于一枚Java程序员来讲,这个吃饭的家伙毫无疑问是:IntelliJ IDEA图片

所属专栏

相关下载

  • 【本专栏源代码】:https://github.com/yourbatman/FXP-java-ee
  • 【技术专栏源代码大本营】:https://github.com/yourbatman/tech-column-learning
  • 【女娲Knife-Initializr工程】访问地址:http://152.136.106.14:8761
  • 【程序员专用网盘】公益上线啦,注册送1G超小容量,帮你实践做减法https://wangpan.yourbatman.cn
  • 【Java开发软件包(Mac)】:https://wangpan.yourbatman.cn/s/rEH0 提取码:javakit

版本约定

  • Mac OS 12.2
  • iTerm2 3.4.14(zsh 5.8)
  • IntelliJ IDEA 2021.3.2

✍正文

几乎每个软件或多或少都会有快捷键,由此来提高使用效率。几乎每个人都愿意相信快捷键是能够提高效率的,但常常还是一个鼠标走天下。

研发人员效率的最大障碍是什么

图片鼠标,鼠标,还是tm的鼠标。

诚然,鼠标是现代计算机不可或缺的外设。它极大程度降低了使用计算机的门槛,但作为各自领域的专业人士,追求效率应当:重(双手操作的)键盘,轻(单手操作的)鼠标

本文将以IDEA为例,笔者分享自己在使用快捷键上的一些实战心得。

IDEA快捷键模板如何选择?

说明:每个软件的快捷键,(没有冲突的情况下)保持默认是最好的,十分不建议自定义

关于IDEA快捷键模板这块,笔者得承认自己是走了好几年“弯路”的,经验教训在这里分享出来。

如下图所示,这是笔者很长时间(2017-2021长达4年之久)使用的快捷键模板:基于Eclipse快捷键模板私人定制版图片下面对这两个“关键词”进行解释解释。

✌Eclipse快捷键模板

对于大多数新生代程序员(2016年之后入行)来讲,Eclipse大概率只听过但没用过,那值得恭喜:没有快捷键切换的包袱。

IntelliJ IDEA相较于Eclipse是后起之秀,早已成为JVM生态IDE领域绝对霸主。如下图所示(2021年统计的结果):JVM圈最受欢迎的IDE,IntelliJ IDEA可谓遥遥领先。图片IDEA超越Eclipse有几个关键时间点,留个印象:

  • 2001年1月:首个IntelliJ IDEA版本正式发布
  • 2012年12月:IntelliJ IDEA支持炫黑主题。也是这一年,IntelliJ IDEA的综合表现实现了对老牌免费IDE Eclipse的超越,然后慢慢侵蚀着它的市占率
  • 2016年:这一年在市占率上,IntelliJ IDEA也完成了对Eclipse的超越。自此,IntelliJ IDEA来到舞台中央,成为JVM圈使用最广泛的IDE

奈何笔者入行较早,2015年8月就已入行(开始使用基于Eclipse的STS),2017年8月入职新公司才首次接触到IntelliJ IDEA。2年,你知道这2年我怎么过的吗?图片这2年经过不断操练,Eclipse快捷键早已成为肌肉记忆,难以“摆脱”。

2017年入职新公司必须使用IntelliJ IDEA的时候,碍于工作压力,我毅然决定沿用Eclipse的快捷键习惯,该决定便是我走弯路的开始。

当初为何没有选择适应IntelliJ IDEA而选择沿用Eclipse的快捷键呢?这可能就是没有逃脱人性的弱点喽:舒适区。

回头想想,这是一个只看到短期收益而忽略了长期价值的决定,是不明智的。如果上天再给我一次机会,我觉得正确的做法是:短期内(比如半年内)先沿用Eclipse的快捷键方案以确保入职新公司后不会因为IDE问题而让开发效率打折扣,但之后(比如半年以后)对公司业务、人员比较熟悉后,能腾出时间了就一定要记得回归“正道”,全面拥抱变化

笔者目前情况:已全部切回IntelliJ IDEA原生方式(默认的Mac OS快捷键模板),可喜可贺?。

✌个人定制版

每个IDE都提供自定义快捷键的能力,IntelliJ IDEA自然也不例外。所以,我在这里又走了弯路:自定义了很多快捷键。

我自定义了不少快捷键,好处是:自个用起来更顺手。但缺点非常明显:在其它人电脑上,我就像个“盲人”

自定义虽好,但也不要贪用哦。个人经验,若真需要DIY快捷键,那么:只做增加,不做修改,以保持和别人的最大公约数不会改变,自然也就拥有更好的“兼容性”。

说明:快捷键表面看起来是私有行为,但其实它的普适性也是非常重要的

IntelliJ IDEA快捷键

接下就是“正文”了,笔者将自己常用的一些快捷键分享出来,供你参考。按照功能大类,分别展开。

✌导航/查找物件

在我眼中,这部分最重要的。

查找的重要性不言而喻,如何能快速定位到自己想要的类、文件、地点,将能直接体现出对IDEA的熟练程度,自然也会节约你非常非常多的时间。

终极查找/导航

Action Name Key
Find Action... command + shift + A

上来就放大招:终极导航。一般的快捷键是执行某个Action,而它是查找Action,只需知道Action Name就能通过它(间接)导航过去,并且还帮你显示了对应快捷键哦。图片说实话,此快捷键笔者使用得并不多,毕竟通过它得经过2步才能“到达”目的地,但它对“新手”是很友好的,所以也推荐一下。

打开/查找类

Action Name Key
Go to Class... command + o

IntelliJ IDEA里笔者认为最最最常用的快捷键,甚至没有之一

图片command + o在整个操作系统层面都具有非常明确的语义,所有用户都知道不需要“教训”。该快捷键在IDEA里被定义为查找/打开类,足矣见得它的高频性和重要性。

其实,不仅仅是IDEA,IntelliJ旗下的其它IDE产品都赋予了command + o非常重要的语义,如:golandDataGrip图片图片Tips:这种查找方式只匹配类名/表名/go文件名,不关心里面的内容,所以检索速度非常非常非常快

小技巧

有时候需要打开某个二方、三方库里的某个类的源代码,使用command + o找对应的类可能找不到:如ArrayList图片默认情况下command + o检索的scope范围是:Project Files(当前工程)。上图可以看到(当前工程)没有找到ArrayList,IDEA非常“智能”的告诉了你如何去做:将搜索范围改为All places

说明:具有确定性的搜索结果能给予用户最好的使用体验,而并非检索出来一大推结果还需人工二次筛选,(无法盲操作)大大降低效率。确定性一般通过缩小检索范围 + AI人工智能推测来实现,IntelliJ IDEA就是这么做的,很高级

将搜索范围改为All places有两种做法:

  1. 使用鼠标点击选择:依旧没有脱离鼠标,不推荐图片
  2. 再按一次command + o:全键盘操作,推荐通过command + o可以实现Project Files和All Places的自由切换,非常方便。

另外,还有一个查找小技巧是模糊搜索,也很常用。比如你在检索时是否遇到这种情况:

  • 不记得类的全名,只记得前面部分,或者中间部分,或者最后部分,甚至只记得零零碎碎的几个字母
  • 类名太长,不想全部输入(太慢)

举个栗子,要打开EntityManagerFactoryDependsOnPostProcessor这个类,我的做法是只在搜索框里这么输入就可以迅速打开我想要的:图片

说明:从Eclipse迁移过来的小伙伴喜欢使用*这列通配符去模糊匹配,在IntelliJ IDEA里就duck不必这么做了,因为它足够智能(当然你写*也是阔以的)。

使用误区

非常非常非常多同学在查找/打开类时有个使用误区:使用File in Files搜索一切,就像这样图片对于这样的结果,你不觉得乱花渐欲迷人眼么?如果你也是这么做的,那么从看到笔者这篇文章开始就默默的改正哈。

问题来了,这两种检索有什么区别呢?

  • Go to Class...:有且仅检索类名,所以内部类也是可以被非常快速检索到的
    • 注意:不是文件名,而是类名。只是单文件单类在99.9999%情况下名称都相同而已,所以不要有误解哈
  • Find in Files:用于检索文件的内容。当你需要关心文件内容的时候(如配置key的名称、字符串内容等)就使用它

总结:如若你现在还使用Find in Files来进行打开类的话,会发现可能90%都是干扰项,觉得还能提高效率嘛?那你还会继续使用吗?

打开/查找文件

Action Name Key
Go to File... command + shift + o

它用于根据文件名查找/打开文件。图片可以看到,它会将文件的后缀名也显示出来。理由很简单:它检索的是文件,文件,文件(后缀名不一样就是不同文件)。

我再“变个戏法”以加深理解:图片可以看到,“同样名称”的.java.class文件都被搜到了,这就是查找文件的“强大之处”。

一般来讲,shift功能键是同类功能做加强,这里应该能体会到吧

笔者眼中的最佳实践:找类用command + o,而command + shift + o专用来找配置文件(当前project或者lib包内)、普通文件。

打开/查找符号

Action Name Key
Go to Symbol... command + option + o

理解这个快捷键的关键,在于理解什么叫Symbol(符号),笔者根据自己的使用经验,尝试帮你总结一下,包括:

  • Class类
  • 方法名
  • 在Spring容器里的Bean名称
  • 枚举项
  • 全局(静态)属性名
  • 成员(静态)属性名
  • Rest URI路径
  • ...图片图片非常“强悍”有木有,总而言之,能够成为类的一部分的都可以通过它找到,这得益于Java强类型、静态语言的特性,用好了可大大提效,谁还说Java语言编程没有脚本语言快呢?

Tips:这个检索的内容虽然多,但速度也还是非常快的。道理很简单:结构化的元素找起来就是快。

打开/查找测试

Action Name Key
Go to Test command + shift + t

光标定位在类内部的任何位置,可快速跳转到对应的测试类or快速创建该类的测试用例。图片如果你也“喜欢”写UT,保证代码质量,相信这个快捷键能节约你不少时间。

✌查找、替换文字/内容

类似于全文查找,功能强大。

在当前文件查找

Action Name Key
Find... command + f
Replace... command + r(查找并替换
图片

在所有文件查找

Action Name Key
Find in Files... command + shift + f
Replace in Files... command + shift + r(查找并替换

是查找当前文件的加强版(所以看到没,加了shift功能键)。图片

Tips:默认情况下也只会在当前项目(In Project)下查找。如上图所示,Scope也是可调整的哈

这个快捷键因为“强大”,被很多同学误用。正所谓通用性和精确性往往不可兼得,建议专键专用。再提醒一次:不要误用,不要误用,不要误用

✌查找代码

查找代码是个很宽泛的说法,比如说我们经常需要知道这个类/变量在哪些地方被用到了、类的继承结构是怎么样的、在哪儿申明的...这些都可认为是查找代码的范畴。

所有使用的地方(窗口形式)

Action Name Key
Find Usages in File... option + F7

注意:这个快捷键不是command组合哟

选中类元素(类、接口、变量、属性、方法...),按此快捷键可以显示出该元素在哪些地方被使用到了。图片这种窗口方式对于某元素被很多地方使用的时候比较有好,因为可以分工程、分jar包、分目录的进行展示,清晰明了,一般用于查找中大型框架里面的引用情况(如Spring框架、MyBatis框架等)。

但是,对于我们自己书写的一些元素,毕竟不太可能被很多地方用到,这个时候使用下面的列表形式可能更为合适。

所有使用的地方(列表形式)

Action Name Key
Show Usages... command + option  + F7

图片这种方式显示的信息没有那么的全,所以快捷性更强,操作方便。

笔者的习惯是,使用它为主,使用上面的窗口形式为辅。

元素声明处/使用处

Action Name Key
Go to Declaration or Usages... command + b

该快捷键有两个作用:

  1. 跳到元素的声明处(若光标处在元素使用的地方)
    1. 99.99%情况下声明是不存在歧义的,所以按下此快捷键会直接调转到“目的地”
  2. (列表形式)展示出使用该元素的地方,效果同option + command + F7

现在知道笔者为何喜欢使用列表形式了吧,因为大部分情况下这一个快捷键搞定:声明、使用两大功能,岂不快哉。

Tips:该快捷键功能同鼠标操作的 按住command + 鼠标单击。即使如此,还是建议,远离鼠标,远离鼠标,远离鼠标

实现

Action Name Key
Go to implement(s)... command + option + b

注意:接口的实现、类的继承都属于该范畴。这里笔者以一个抽象类为例:图片

若某接口/类的实现有多个,则会弹窗让你选择,否则(只有一个实现)就直导航过去了。当然喽,若没有任何实现,就会弹窗提示说没有任何实现。图片

Tips:该快捷键功能同鼠标操作的 按住command + option  + 鼠标单击。即使如此,还是建议,远离鼠标,远离鼠标,远离鼠标

请注意本功能和上面的“元素声明处/使用处”的区别哈,前者要求必须要有继承/实现关系,后者只需有使用就能查找到(毕竟,继承/实现也属于一种使用嘛)。

类的层次/继承树

Action Name Key
Type Hierarchy control + h

某些复杂的场景,某个类的继承关系相当的多,这个时候通过层次/树的方式来查看是最好的。图片该快捷键很好的对上面的command + option + b(实现)形成了补充:

  • 当某个类/接口的实现较少时,使用command + option + b即可快速导航
  • 当某个类/接口的实现较多时,或者想关注层次结构时,那就使用本快捷键吧

文件结构(列表方式)

Action Name Key
File Structure command + F12

结构就相当于“解刨”,该快捷键可以快速看到某个类的所有元素,包括:所有成员、所有方法图片说明:加入某个类的结构元素很多,那在下面的窗口方式查看更为合适。

文件结构(窗口方式)

Action Name Key
File Structure command + 7

图片该窗口上面附有工具栏,可格局需要进行展示、隐藏、展开、排序等操作,非常方便。

✌其它导航

其它导航并非不重要,而是不方便分大类,所以列为其它吧。

上一次修改

Action Name Key
Last Edit Location command + shift + delete

这个快捷键巨好用且非常智能。

  • 好用体现在:将你从任意地方瞬间带回到现场,接着思绪敲代码
  • 智能体现在:你在“同一个地方”编辑多次只会算作一次,智能决策

比如你在浏览了其它代码、框架源码若干时间后,不知道自己写到哪了,使用它即可一键召回。按1次回到上次编辑处,按2次回到上上次,3次就是上上上次,依此类推...

Tips:IDEA会记住你最近编辑的地方,所以能快速回去。但是,一旦重启IDEA就会清空“记忆”哈

你可能会问有没有Next Edit Location(下一次修改)的功能,答案是有的,但IDEA默认并没有帮你绑定快捷键,笔者估计是IDEA觉得(大部分场景下)这可以使用前进、后退快捷键代替,让使用者可以少记忆一个吧。

下一个错误

Action Name Key
Next Highlighted Error F2
Previous Highlighted Error shift + F2

当一个类里错误较多时,使用该快捷键可快速定位错误所在地,非常方便和快速。图片用鼠标操作看似问题不大,但谨记咱们的目标:尽量的脱离鼠标。

前进、后退

Action Name Key
Back command + [ command + option + ←
Forward command + ] command + option + →

这两个快捷键非常非常非常常用,不解释。

行、列

Action Name Key
Go to Line:Column command + l

快速定位到当前文件的行、列位置。图片该快捷键最常见的使用场景:

  • 抛出异常时,异常栈里会显示错误的行、列
  • 代码静态检查时,会展示错误的具体行、列

使用此快捷键可快速定位到错误处,非常方便。

行头/行尾

Action Name Key
Move Caret to Line Start command + ←或者option + a
Move Caret to Line end command + →或者option + e

还记得操作系统级别的行头、行尾快捷键吗?回忆一下下图:图片IDEA因为处在编辑框里,因此针对性的提供了响应快捷键。

Tips:总结来看,回到行头/行尾的快捷键有好几个了,具体使用哪个?根据个人习惯使用即可

另外,还有些基础键可结合(以上快捷键)一起使用:

  • option+左右:一次移动一个单词
  • shift+左右:选中

✍总结

21世纪的今天,没有导航软件,如同盲人?在IDEA里亦是如此,没有(快捷键)导航,使用的效率将大打折扣。

本文主要介绍了IDEA快捷键---导航篇,提纲挈领了一下,剩下的就是练习,练习,再练习了!快捷键没有任何技巧性,练就完了!假期里多操练几遍,你就是下一个高手。

下篇继续介绍Intellij IDEA的实用快捷键。那,咱们下篇再见!

2022农历虎年春节这一天,还能持续看到这里的同学,给自己鼓个掌。祝:虎年一切都好!

本专栏上下文

推荐阅读

图片

我是方向盘(YourBatman):一个前25年还不会写Hallo World、早已毕业的大龄程序员。网瘾失足、清考、延期毕业、房产中介、保险销售、送外卖...是我不可抹灭的黑标签

  • ??2006 - 2009:高中时期为游戏《梦幻西游》骨灰玩家
  • ?2013.07 清考、毕业答辩3次未通过、延期毕业
  • ?2013.08-2014.07 宁夏中介公司卖二手房1年,毕业后第1份工作
  • ️️?2014.07-2015.05 荆州/武汉,泰康人寿卖保险3月、饿了么送外卖2月,还有炸鸡排、直销等第2345份工作
  • ?2015.08 开始从事Java开发,闯过外包,呆过大厂!多年架构经验,任基础架构/中间件团队负责人
  • ?2021.08 因“双减政策”失业!历经9面,终获美团外卖L8的offer
  • ??‍♀️Java架构师、Spring开源贡献者、CSDN博客之星年度Top 10、领域建模专家、写作大赛1/2届评委
  • ?将出版书籍《Spring奇淫巧技》,致力于很好、很具深度、很实用的专栏,为市场贡献微薄之力
  • 现在写纯粹技术专栏(公号后台回复专栏列表),不哗众取宠。如果你也有共鸣,可加我好友(fsx1056342982)一起进步
图片
序号 专栏名称 简介
01 【方向盘】-程序人生 程序人生,人生程序
02 【方向盘】-资讯/新特性 IDEA、JDK、Spring技术栈......新特性
03 【方向盘】-IntelliJ IDEA 熟练使用IDEA就相当拥有物理外挂,助你高效编码
04 【方向盘】-Bean Validation 熟练掌握数据校验,减少90%的垃圾代码
05 【方向盘】-日期时间 帮你解决JDK Date、JSR 310日期/其实 的一切问题
06 【方向盘】-Spring类型转换 Spring类型转换-框架设计的基石
07 【方向盘】-Spring static static关键字在Spring里的应用
08 【方向盘】-Cors跨域 关于跨域请求问题,本专栏足矣
09 【方向盘】-Jackson Almost Maybe是最好的Jackson专栏
10 【方向盘】-Spring配置类 专讲@Configuration配置类,你懂的
11 【方向盘】-Spring技术栈 暂无所属小分类的,Spring技术栈大分类
12 【方向盘】-JDK 暂无所属小分类的,JDK技术栈大分类
13 【方向盘】-Servlet Servlet规范、Web相关内容专题
14 【方向盘】-Java EE 从Java EE到Jakarta EE,30年弹指一挥间
15 【方向盘】-Spring Boot新特性 Spring Boot中、大版本发布时的新特性系列专题
16 【方向盘】-Spring Framework新特性 Spring Framework中、大版本发布时的新特性系列专题
17 【方向盘】-Spring Cloud新特性 Spring Cloud中、大版本发布时的新特性系列专题
... ... ...
99 源代码库 大多数专栏均配有源代码,都在这里
  • 源代码库地址:https://github.com/yourbatman/tech-column-learning
  • CSDN主页:https://blog.csdn.net/f641385712
  • 掘金主页:https://juejin.cn/user/430664289367192
  • 博客园主页:https://www.cnblogs.com/yourbatman
  • 个人博客主页:https://yourbatman.cn
  • 个人网盘主页:https://wangpan.yourbatman.cn
21590【方向盘】使用IDEA的60+个快捷键分享给你,权为了提效(IDEA导航篇)

root

这个人很懒,什么都没留下

文章评论