1. 程式人生 > >Eclipse編碼規範——Code Templates設置

Eclipse編碼規範——Code Templates設置

reason project reat java類 align ges false ref jdk

Eclipse編碼規範——Code Templates設置

Eclipse編碼規範主要包括三個方面:設置Code Templates、Eclipse formatter、Checkstyle,

本篇主要介紹如何設置Code Templates,具體步驟如下:

打開Window->Preferences->Java->Code Style->Code Templates:

技術分享

我們可以看到Eclipse Code Templates界面中間Configure generated code and comments區域包含了兩個菜單樹:Comment、Code,

Comments代表註釋模板,Code代表代碼模板,其中每一個子菜單代表子項的模板。

當我們點擊Comments下的Files子菜單時,下面的Pattern會顯示Java文件的頭部註釋。

下面詳細列出每一個子項的模板格式:

Comments-->Files(Java文件註釋)

/** 
 * Project Name:${project_name} 
 * File Name:${file_name} 
 * Package Name:${package_name} 
 * Date:${date}${time} 
 * Copyright (c) ${year} All Rights Reserved. 
 * 
 */  

Comments-->Types(Java類註釋)

/** 
 * ClassName: ${type_name} <br/> 
 * Function: ${todo} ADD FUNCTION. <br/> 
 * Reason: ${todo} ADD REASON <br/> 
 * date: ${date} ${time} <br/> 
 * 
 * @author lizm
 * @version ${enclosing_type}${tags} 
 * @since JDK 1.6 
 */  

Comments-->Fields(類字段註釋)

/** 
 * ${field}:${todo}
 * 
@since JDK 1.6 */

Comments-->Constructors(構造函數註釋)

/** 
 * Creates a new instance of ${enclosing_type}. 
 * 
 * ${tags} 
 */  

Comments-->Methods(Java方法註釋)

/** 
 * ${enclosing_method}:(這裏用一句話描述這個方法的作用)
 * ${todo}(這裏描述這個方法適用條件 – 可選)
 * ${todo}(這裏描述這個方法的執行流程 – 可選)
 * ${todo}(這裏描述這個方法的使用方法 – 可選)
 * ${todo}(這裏描述這個方法的註意事項 – 可選) 
 * 
 * @author ${user} 
 * ${tags} 
 * @since JDK 1.6 
 */ 

Comments-->Overriding methods(重寫方法註釋)

/** 
 * ${todo} 簡單描述該方法的實現功能(可選). 
 * ${see_to_overridden} 
 */  

Comments-->Delegate methods(代理方法註釋)

/** 
 * ${tags} 
 * ${see_to_target} 
 */  

Comments-->Getters(Java Getter方法註釋)

/** 
 * ${bare_field_name}. 
 * 
 * @return  the ${bare_field_name} 
 * @since   JDK 1.6 
 */  

Comments-->Setters(Java Setters方法註釋)

/** 
 * ${param}. 
 * 
 * @param   ${param}    the ${bare_field_name} to set 
 * @since   JDK 1.6 
 */  

Code-->New Java files(新建java文件代碼模板/**

 * Project Name:${project_name} 
 * File Name:${file_name} 
 * Package Name:${package_name} 
 * Date:${date}${time} 
 * Copyright (c) ${year}, [email protected] All Rights Reserved. 
 * 
*/  
${filecomment}  
  
${package_declaration}  
/** 
 * ClassName:${type_name}
 * Function: ${todo} 
 * Reason:   ${todo}  
 * Date:     ${date} ${time} 
 * @author   ${user}   
 * @since    JDK 1.6 
 *       
 */  
${typecomment}  
${type_declaration} 

Code-->Method body(方法體模板)

// ${todo} Auto-generated method stub  
${body_statement}  

Code-->Constructor body(構造函數模板)

${body_statement}  
// ${todo} Auto-generated constructor stub  

Code-->Getter body(字段Getter方法模板)

return ${field};  

Code-->Setter body(字段Setter方法模板)

${field} = ${param}; 

Code-->Catch block body(異常catch代碼塊模板)

// ${todo} Auto-generated catch block  
${exception_var}.printStackTrace();  

還有一種方式就是直接導入設置好的模版文件codetemplates.xml,

其中codetemplates.xml內容如下:

<?xml version="1.0" encoding="UTF-8" standalone="no"?><templates><template autoinsert="false" context="gettercomment_context" deleted="false" description="Comment for getter method" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.gettercomment" name="gettercomment">/**  
 * ${bare_field_name}.  
 *  
 * @return  the ${bare_field_name}  
 * @since   JDK 1.6  
 */</template><template autoinsert="false" context="settercomment_context" deleted="false" description="Comment for setter method" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.settercomment" name="settercomment">/**  
 * ${param}.  
 *  
 * @param   ${param}    the ${bare_field_name} to set  
 * @since   JDK 1.6  
 */</template><template autoinsert="false" context="constructorcomment_context" deleted="false" description="Comment for created constructors" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.constructorcomment" name="constructorcomment">/**  
 * Creates a new instance of ${enclosing_type}.  
 *  
 * ${tags}  
 */  
</template><template autoinsert="false" context="filecomment_context" deleted="false" description="Comment for created Java files" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.filecomment" name="filecomment">/**  
 * Project Name:${project_name}  
 * File Name:${file_name}  
 * Package Name:${package_name}  
 * Date:${date}${time}  
 * Copyright (c) ${year}, [email protected] All Rights Reserved.  
 *  
 */</template><template autoinsert="false" context="typecomment_context" deleted="false" description="Comment for created types" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.typecomment" name="typecomment">/**  
 * ClassName: ${type_name} &lt;br/&gt;  
 * Function: ${todo} ADD FUNCTION. &lt;br/&gt;  
 * Reason: ${todo} ADD REASON(可選). &lt;br/&gt;  
 * date: ${date} ${time} &lt;br/&gt;  
 *  
 * @author ${user}  
 * @version ${enclosing_type}${tags}  
 * @since JDK 1.6  
 */</template><template autoinsert="false" context="fieldcomment_context" deleted="false" description="Comment for fields" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.fieldcomment" name="fieldcomment">/**  
 * ${field}:${todo}(用一句話描述這個變量表示什麽).  
 * @since JDK 1.6  
 */</template><template autoinsert="false" context="methodcomment_context" deleted="false" description="Comment for non-overriding methods" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.methodcomment" name="methodcomment">/**  
 * ${enclosing_method}:(這裏用一句話描述這個方法的作用). &lt;br/&gt;  
 * ${todo}(這裏描述這個方法適用條件 – 可選).&lt;br/&gt;  
 * ${todo}(這裏描述這個方法的執行流程 – 可選).&lt;br/&gt;  
 * ${todo}(這裏描述這個方法的使用方法 – 可選).&lt;br/&gt;  
 * ${todo}(這裏描述這個方法的註意事項 – 可選).&lt;br/&gt;  
 *  
 * @author ${user}  
 * ${tags}  
 * @since JDK 1.6  
 */</template><template autoinsert="false" context="overridecomment_context" deleted="false" description="Comment for overriding methods" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.overridecomment" name="overridecomment">/**  
 * ${todo} 簡單描述該方法的實現功能(可選).  
 * ${see_to_overridden}  
 */</template><template autoinsert="true" context="delegatecomment_context" deleted="false" description="Comment for delegate methods" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.delegatecomment" name="delegatecomment">/**  
 * ${tags}  
 * ${see_to_target}  
 */</template><template autoinsert="false" context="newtype_context" deleted="false" description="Newly created files" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.newtype" name="newtype">/**  
 * Project Name:${project_name}  
 * File Name:${file_name}  
 * Package Name:${package_name}  
 * Date:${date}${time}  
 * Copyright (c) ${year}, [email protected] All Rights Reserved.  
 *  
*/  
${filecomment}  
  
${package_declaration}  
/**  
 * ClassName:${type_name} &lt;br/&gt;  
 * Function: ${todo} ADD FUNCTION. &lt;br/&gt;  
 * Reason:   ${todo} ADD REASON. &lt;br/&gt;  
 * Date:     ${date} ${time} &lt;br/&gt;  
 * @author   ${user}  
 * @version    
 * @since    JDK 1.6  
 * @see        
 */  
${typecomment}  
${type_declaration}  
</template><template autoinsert="true" context="classbody_context" deleted="false" description="Code in new class type bodies" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.classbody" name="classbody">  
</template><template autoinsert="true" context="interfacebody_context" deleted="false" description="Code in new interface type bodies" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.interfacebody" name="interfacebody">  
</template><template autoinsert="true" context="enumbody_context" deleted="false" description="Code in new enum type bodies" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.enumbody" name="enumbody">  
</template><template autoinsert="true" context="annotationbody_context" deleted="false" description="Code in new annotation type bodies" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.annotationbody" name="annotationbody">  
</template><template autoinsert="true" context="catchblock_context" deleted="false" description="Code in new catch blocks" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.catchblock" name="catchblock">  
// ${todo} Auto-generated catch block  
${exception_var}.printStackTrace();  
</template><template autoinsert="false" context="methodbody_context" deleted="false" description="Code in created method stubs" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.methodbody" name="methodbody">  
// ${todo} Auto-generated method stub  
${body_statement}</template><template autoinsert="true" context="constructorbody_context" deleted="false" description="Code in created constructor stubs" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.constructorbody" name="constructorbody">  
${body_statement}  
// ${todo} Auto-generated constructor stub  
</template><template autoinsert="true" context="getterbody_context" deleted="false" description="Code in created getters" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.getterbody" name="getterbody">return ${field};</template><template autoinsert="true" context="setterbody_context" deleted="false" description="Code in created setters" enabled="true" id="org.eclipse.jdt.ui.text.codetemplates.setterbody" name="setterbody">${field} = ${param};</template></templates>  

設置Code Templates的目的主要是為了統一各種註釋的格式以及代碼的模板;

Eclipse編碼規範——Code Templates設置