首页 > 代码库 > eclipse 自动为getter和setter添加中文注释

eclipse 自动为getter和setter添加中文注释

在我们使用eclipse进行开发的时候常常会使用到eclipse自动生成getter和setter的功能,然后大多情况下eclipse为我们生成的getter和setter都是无法在项目中使用的。还需要我们自己手动修改。

比如下面这个类。我使用了eclipse的自动生成getter和setter的功能并且选择了添加注释。最终的类为如下

public class User {
	//用户名
	private String name;

	/**
	 * @return the name
	 */
	public String getName() {
		return name;
	}

	/**
	 * @param name the name to set
	 */
	public void setName(String name) {
		this.name = name;
	}
	
}

但是我们想要的不是这样一个注释。希望能够产生如下的代码注释

public class User {
	// 用户名
	private String name;

	/**
	 * 返回 用户名
	 * 
	 * @return 用户名
	 */
	public String getName() {
		return name;
	}

	/**
	 * 设置 用户名
	 * 
	 * @param name
	 *            用户名
	 */
	public void setName(String name) {
		this.name = name;
	}

}

如何来做呢?

现在我就来说明一下我的修改方式。

1、第一步是查找到eclipse自动生成getter和setter的类文件。我给大家找好了在eclipse\plugins\org.eclipse.jdt.ui_xxxxxxxx.jar\org\eclipse\jdt\internal\corext\codemanipulation\GetterSetterUtil.class

2、我们修改这个class的源码然后编译替换。这个class源码一般在对应的eclipse\plugins\org.eclipse.jdt.ui.source__xxxxxxxx.jar\org\eclipse\jdt\internal\corext\codemanipulation\GetterSetterUtil.java

我的eclipse版本为Version: 4.3.1

我把已经修改好和编译好的文件传上来。在你们使用这个的时候记得先把原始jar进行备份。以免悲剧。

关于class的替换过程我还是简单说下。免得有的同学不明白。

1、直接用压缩文件打开eclipse\plugins\org.eclipse.jdt.ui_xxxxxxxx.jar

2、找到org\eclipse\jdt\internal\corext\codemanipulation\GetterSetterUtil.class

3、将GetterSetterUtil.class替换为我们自己修改好的GetterSetterUtil.class(eclipse没有运行的状态下才能替换)

使用方法

1、在eclipse中window-》preferences->java->code style->code templates

2、找到comments

3、 展开找到getters点击Edit输入如下内容

/**
 * 返回 bare_field_comment
 * 
 * @return bare_field_comment
*/

4、找到setters 点击edit 输入如下内容

/**
 * 设置 bare_field_comment
 * 
 * @param ${param}
 *            bare_field_comment
 */

5、保存


bare_field_comment :是用我们属性上面的这个注释来替换。如果属性上面没用注释的话。那么会直接输出bare_field_comment

使用

public class User {
	// 用户名
	private String name;
}


在我们自动生成getter和setter的时候同样选中 generate method comments 如果属性上面有单行注释那么这个注释就会被我们使用到。

最终生成效果如下

public class User {
	// 用户名
	private String name;

	/**
	 * 返回 用户名
	 * 
	 * @return 用户名
	 */
	public String getName() {
		return name;
	}

	/**
	 * 设置 用户名
	 * 
	 * @param name
	 *            用户名
	 */
	public void setName(String name) {
		this.name = name;
	}
}


注意的是

多行注释是不被识别的。这个是故意屏蔽掉的。

下载地址

http://download.csdn.net/detail/kongguoan/7693671