java基础- Java编程规范与注释
一 前言
java编程规约是指在java代码编写过程中通俗的约定;通常我们是要遵守这些规范;这好比我们在生活中要遵守的道德准则,如果你做的事情超出了道德的底线,那就有可能会受到社会抨击;在java编程中也是类似的道理,如果你编写的代码不是很规范,尽管功能实现的功能强大,但其他java编程人员都看不懂你的代码,别人就认为你这是垃圾代码,后期的维护工作就会很艰难,而且心里肯定对你很不爽;如果在工作中遇见这种情况,你l的eader就有可能让你重写编写代码;
二 命名规范
良好的代码命名规则习惯有助于我们快速浏览代码,让代码的可读性强,易于他人阅读,后期维护工作简单;
2.1 驼峰命名法
驼峰命名法(Camel-Case)是程序编程的通俗约定,其分为大驼峰写法和小驼峰写法;
- 大驼峰:每一个单词首字母大写,随后的字母小写;示例:ILoveJavaProgramer
- 小驼峰: 第一个单词全小写,之后的单词首字母大写,其余字母小写;示例:iLoveJavaProgramer
2.2 包名写法
比如我有个域名是: java.com; 我现在要创建工程的包结构,那么通常包的命名规则是将域名反写,之后跟具体的包名;所有的包名都统一使用小写;
示例:com.java.zszxz.service
2.3 类名,接口名,文件名写法
类名,接口名,文件名写法统一采用大驼峰写法;
示例:
- 类名:FileInputStream
- 接口名:InputStream
- 文件名:UserMapper.xml
2.4 方法名,字段名写法
方法名 和 字段名称 统一采用小驼峰命名写法;
示例:
- 方法名:getUser()
- 字段名: fieldInfomation
2.4 常量名写法
常量是特殊的字段,也就是特殊的变量,其约定的写法跟之前稍有不同,其采用的写法是所有单词的字母都大写,单词之间使用下划线隔开;
示例: I_LOVE_JAVA_PROGRAMER
三 代码注释
代码的注释的作用主要是进行代码解释,类似你买了一个硬件设备,你要看说明书才知道怎么用这个设备,注释就起到了说明书的功能;代码注释的第二个功能是能注释到你当前写的代码,但后面又可能用到该代码,舍不得删除的情况;
3.1 单行注释
单行注释源于c++,其意指能注释掉一行代码,使用两个斜杆(//);
示例: // 我是知识追寻者,你是谁?觉得文章不错能帮助到你,那还不关注下?
3.2 多行注释
多行注释的风格源于c;其是斜杆和星号开头,中间部分是内容,以星号和斜杆结束(/* ............... */);
示例: /* 今天你的小伙伴来找你了吗? */
3.3 文档注释
文档注释是指能够通过jdk的javadoc命令使注释生成html帮助文档,比如开发人员常看的jdk 的 API帮助文档;使用格式是以斜杆和2个星号开头,中间是内容,以星号和斜杆结束(/** .................... */);
通常文档注释只对 public 和 protect 级别的的成员进行注释,内部私有的成员是不提供给外部;
常用标签介绍:
| @see | 引用其他类,使用方式: @see className, @see className#MethodName ,@see qualifiedClassName |
| @link | 引用其他类,使用方式: {@link className, @link className#methodName} |
| @docRoot | 生成文档的相对路径通常和a标签混用,使用方式:{@docRoot /path/childPath/**.thml} |
| @version | 工程的版本信息,使用方式:{@vsersion information} |
| @param | 方法参数说明,使用方式: @param paramName |
| @return | 方法的返回值,使用方式:@return information |
| @deprecated | 类,成员或者接口已过时,不久就会被废弃 ,使用方式 :@deprecated information |
| @throws | 抛出的异常,使用方式 @throws ExceptionClassName |
| @since | 文档标题,使用方式 @since information |
| @author | 作者信息,使用方式 @author information |
了解更多标签示例请看:java文档注释
使用示例:
public class Doc {
@Deprecated
private String buguaiguai;
private String love;
/**
* @see java.lang.Object#toString()
* @see java.lang.String
* @see String
* {@link System}
* {@link System#getProperties()}
* <a href="{@docRoot}/java/lang/doc-files/ValueBased.html">value-based</a>
* @param love is favorite
* @return the love
* @deprecated <p>buguaiguai</p>
* @throws RuntimeException contribution the java world
* @since zszxz
* @version 1.0.0
* @author lsc/zszxz/youku1327
*/
public String getLove(String love){
return "love";
}
}
生成doc命令
javadoc -d tagerPath sourcePath/className.java
命令过程:
C:\Users\林>javadoc -d C:\mydata\generator\doc C:\java\workspaceforresource\study-01\base\src\main\java\com\youku1327\base\doc\Doc.java
正在加载源文件C:\java\workspaceforresource\study-01\base\src\main\java\com\youku1327\base\doc\Doc.java...
正在构造 Javadoc 信息...
正在创建目标目录: "C:\mydata\generator\doc\"
标准 Doclet 版本 1.8.0_131
正在构建所有程序包和类的树...
正在生成C:\mydata\generator\doc\com\youku1327\base\doc\Doc.html...
正在生成C:\mydata\generator\doc\com\youku1327\base\doc\package-frame.html...
正在生成C:\mydata\generator\doc\com\youku1327\base\doc\package-summary.html...
正在生成C:\mydata\generator\doc\com\youku1327\base\doc\package-tree.html...
正在生成C:\mydata\generator\doc\constant-values.html...
正在构建所有程序包和类的索引...
正在生成C:\mydata\generator\doc\overview-tree.html...
正在生成C:\mydata\generator\doc\index-all.html...
正在生成C:\mydata\generator\doc\deprecated-list.html...
正在构建所有类的索引...
正在生成C:\mydata\generator\doc\allclasses-frame.html...
正在生成C:\mydata\generator\doc\allclasses-noframe.html...
正在生成C:\mydata\generator\doc\index.html...
正在生成C:\mydata\generator\doc\help-doc.html...
C:\Users\林>
生成结果:

四 空行与缩进
4.1 空行
空行是指不同功能的代码之间要做到空行,以便于区分;
- 通常类名接口名,与其成员保持2个空行,如果有注释其也算一个空行;
- 不同类别的成员之间保持一个空行;
- 方法逻辑与方法名空一行;
示例:
/*
* 类的注释不需要空行
* /
public class zszxz {
// 成员与类或者接口包池2个空行,包括注释;
private String love;
private Integer age; // 不同类别的成员保持一行
private String gender;// 相同类名的成员不用空行
public String getLove(){
return "love"; // 方法逻辑与方法名空一行
}
}
4.2 缩进
类和属性;方法和逻辑;它们之间的缩进都是以4个空格为单位,可以使用制表符来代替多个空格,作者的一个制表符设置的是2个空格;
示例:
/*
* 类的开头不需要空格
* /
public class zszxz {
// 成员与类或者接口保持4个空格
private String love;
private Integer age; // 成员与类或者接口保持4个空格
private String gender;// 成员与类或者接口保持4个空格
public String getLove(){ //成员与类或者接口保持4个空格
return "love"; // 方法逻辑与方法名保持4个空格
}
}

java基础- Java编程规范与注释的更多相关文章
- java基础-网络编程(Socket)技术选型入门之NIO技术
java基础-网络编程(Socket)技术选型入门之NIO技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.传统的网络编程 1>.编写socket通信的MyServer ...
- Java基础-Java中23种设计模式之常用的设计模式
Java基础-Java中23种设计模式之常用的设计模式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.设计模式分类 设计模式是针对特定场景给出的专家级的解决方案.总的来说设 ...
- Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock)
Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在学习Java的之前,你可能已经听说过读 ...
- java基础---->java中正则表达式二
跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...
- Java基础-Java中的堆内存和离堆内存机制
Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
- Java基础-Java中的内存分配与回收机制
Java基础-Java中的内存分配与回收机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一. 二.
- Java基础-Java中的并法库之线程池技术
Java基础-Java中的并法库之线程池技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是线程池技术 二.
- Java基础-JAVA中常见的数据结构介绍
Java基础-JAVA中常见的数据结构介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是数据结构 答:数据结构是指数据存储的组织方式.大致上分为线性表.栈(Stack) ...
- Java基础-Java数据类型
Java基础-Java数据类型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数据类型的作用 数据类型就是一组值,以及这一组值上的操作,数据类型可以决定数据的存储方式,取值范围 ...
- java三元表达式编程规范问题
package day01; public class Program { public static void main(String[] args) { // TODO Auto-g ...
随机推荐
- eNSP仿真软件之配置Trunk口
实验原理 在以太网中,通过划分VLAN来隔离广播域和增强网络通信的安全性.以太网通常由多台交换机组成,为了使VLAN的数据帧跨越多台交换机传递,交换机之间互连的链路需要配置为干道链路(Trunk Li ...
- MySQL数据库优化技巧有哪些?
开启查询缓存,优化查询. explain你的select查询,这可以帮你分析你的查询语句或是表结构的性能瓶颈.EXPLAIN的查询结果还会告诉你你的索引主键被如何利用的,你的数据表是如何被搜索和排序的 ...
- Coding,命名是个技术活
来吧 日常编码少不了的事情就是给代码命名,代码中命名的重要性在项目前期不会有太大感受,因为是边做边命名,代码天天见,自然会加深记忆.但到了后期上线后半年一年后,再回过头看的时候,我擦,这个变量是啥意思 ...
- 在UEFI+GPT下使用rEFind实现Win10 + Kali2.0 双引导
转载自:在UEFI+GPT下使用rEFind实现Win10 + Kali2.0 双引导 https://www.linuxidc.com/Linux/2016-07/133717.htm
- 2019-9-27:渗透测试,metasploit-framework初接触
初次利用metasploit漏洞利用框架,入侵获取win7获取权限 目标机系统:windows7,无修复补丁 目标ip地址:192.168.20.131 任务:利用ms17-010,永恒之蓝漏洞,获取 ...
- 【NHOI2018】扑克游戏
[问题描述] 有一种别样“小猫钓鱼”扑克游戏.有 N 张牌,每张牌都有一个花色和点数.游戏的规则:扑克接龙时,若前面有同样花色的牌,你可以将这两张牌连同之间的牌都取走,得到的分值为取走牌点数之和.这里 ...
- 我的 Input框 不可能这么可爱
<input /> 标签是我们日常开发中非常常见的替换元素了,但是最近在刷 whattwg 跟 MDN 的时候发现 跟 <input /> 有很多相关的属性,选择器都没怎么用过 ...
- Java NIO 三大组件之 Channel
Java NIO 之 Channel 一.什么是Channel Channel用于源节点(例如磁盘)与目的节点的连接,它可以进行读取,写入,映射和读/写文件等操作. 在Java NIO中负责缓冲区中数 ...
- int main (int argc, const char * argv[0]) 中参数的含义;指针数组和数组指针
恩,有的编译器初始化时候会产生这样的参数 argc是命令行总的参数个数,argv[]是argc个参数,其中第0个参数是程序的全名 1. 几种C++ 常见的参数种类 int main(void); in ...
- 限定某个目录禁止解析php、限制user_agent、php相关配置
6月1日任务 11.28 限定某个目录禁止解析php11.29 限制user_agent11.30/11.31 php相关配置扩展apache开启压缩 http://ask.apelearn.com/ ...