背景

开发过程中,需要对类和方法添加注释,类的注释比较好实现,通过设置模板,在创建时即可自动创建预设的注释。而为方法添加注释,则就没那么容易,最主要的影响在于参数的处理上。

对于IDEA,在接口的方法上方输入/**+回车后,会自动创建格式化注释

/**
     * 
     * @param id
     * @return
     */
    Share get(String id);

当对于其他方法,按照上面操作,则只会创建一个简单的多行注释,无参数信息        

/**
     *
     */
    public Share get(String id) {
        Share share=new Share();
        share.setId(id);
        share.setUserId("1");
        share.setTitle("我的分享");
        //使用Feign调用远程服务
        // UserDto userDto = userService.getUser("1");
        UserDto userDtoParam=new UserDto();
        userDtoParam.setId("2");
        UserDto userDto = userService.query(userDtoParam);

        String userName=userDto.getName();
        share.setUserName(userName);
        return share;
    }

那么,如何为任意方法生成模板化的注释,以提升开发效率呢?

方案1:live template功能

实现

对于IDEA,首先想到的是live template功能,可以自定义代码片段,通过自定义缩略语,快速完成,之前自己也配置过,参照以往经验,进行如下配置:

模板定义

/**
 * 
$params$
 * @return    
 */

变量定义

文件注释 copyright All rights reserved 文件注释快捷键_实用技巧

使用内置方法methodParameters来获取参数。

问题

实际运行结果是……

/**
     * 
    
     * @return    
     */
    public void get(String id,String name) {
     
        
    }

发生了什么呢?实际并没有取到方法参数,通过搜索,发现很多人说,只有放到方法内部,才能获取到方法参数,再手工剪贴到方法体外……试了下,确实是这样,但是,这不是折腾吗?不提降低效率这事,就这么个操作法,这得多别扭。

尝试

于是,进一步找寻解决方案,发现有个关键问题,是模板中的/,会导致methodParameters方法失效,要求模板不能有/,然后出现了一种解决办法,即将/*从模板中拿走,由外部输入,即

*
 * 
$params$
 * @return    
 */

这时候,要求输入/*+自定义的缩略词+tab,这时候,参数能读取了,但是多个参数显示成一个数组,这样子……怎么来指定每个参数的含义?

/**
     * 
    [id, name]
     * @return    
     */
   Share get(String id,String name);

此外,网上也有不少人,说缩略词必须设置为*,并且说这样很巧妙,不过我实在看不出巧妙在哪,也试验过,缩略词任意,比如d,只要保证外部输如/*就行了,这种方式,依旧相当别扭。

解决方案

继续探索方案,发现使用groovy脚本来解析参数数组,具体如下:

模板定义

**
 * 
$params$
 * @return    
 */

 变量定义

groovyScript("if(\"${_1}\".length() == 2) {return ' * ';} 
else 
{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());

这是自己进行反复调试后可实现最终期望结果的脚本,网上有很多,存在各种瑕疵,比如,对于无参数的方法,同样会生成一行 @param ,此外常见的还有生成空白行、错位等。

 使用时,只需输入/+ 缩略词+tab即可

/**
     *
     * @param id
     * @param name
     * @return    
     */
   Share get(String id,String name);

方案2:Easy Javadoc插件

从上面可以看出,自己配置这个模板还是比较费劲,还有另外一种思路,使用idea插件,名字为Easy Javadoc,安装后,选中方法名,按快捷键ctrl+\,可以直接生成方法注释,同时,进行翻译,效果如下。

/**
     * 得到
     *
     * @param id   身份证件
     * @param name 名称
     * @return {@link Share}
     */
    Share get(String id,String name);

这个插件有几个地方需要注意:

1.默认的热键ctrl+\与idea内置的一个操作冲突,需要修改下快捷键设置

2.默认的翻译引擎是谷歌,可能因为被墙,并不能正常进行,可在设置里更换为百度翻译或有道翻译