java命名

  |  

Java命名

包命名规范

一般地,包命名常采用顶级域名作为前缀,例如com,net,org,edu,gov,cn,io等,随后紧跟公司/组织/个人名称以及功能模块名称。下面是一些包命名示例:

1
2
3
4
5
6
7
8
package org.springframework.boot.autoconfigure.cloud;
package org.springframework.boot.util;
package org.hibernate.action;
package org.hibernate.cfg;
package com.alibaba.druid;
package com.alibaba.druid.filter;
package com.alibaba.nacos.client.config;
package com.ramostear.blog.web;

类命名规范

类(Class)通常采用名词进行命名,且首字母大写,如果一个类名包含两个以上名词,建议使用驼峰命名法书写类名,每个名词首字母也应该大写。一般地,类名的书写尽量使其保持简单和描述的完整性,因此在书写类名时不建议使用缩写。

1
2
3
4
5
6
public class UserDTO{}
class EmployeeService{}
class StudentDAO{}
class OrderItemEntity{}
public class UserServiceImpl{}
public class OrderItemController{}

接口命名规范

接口(Interface)是一种表述某一类型对象动作的特殊类;简单来说,接口也是类(不太严谨)

所以,接口的名称的书写也应该符合类名书写规范,首字母应该大写,与普通类名不同的是,接口命名时通常采用形容词或动词来描述接口的动作行为。

1
2
3
4
5
6
7
public interface Closeable{}
public interface Cloneable{}
public interface Runnable{}
public interface Comparable<T>{}
public interface CompletionService<V>{}
public interface Iterable<T>{}
public interface EventListener{}

异常类命名规范

异常类(Exception Class)也是类的一种,但与普通类命名不同的是,异常类在命名时需要使用“Exception”作为其后缀。

1
2
3
4
5
6
public class FileNotFoundException{}
public class UserAlreadyExistException{}
public class TransactionException{}
public class ClassNotFoundException{}
public class IllegalArgumentException{}
public class IndexOutOfBoundsException{}

系统异常,这一类异常类的命名使用“Error”作为其后缀,以区分Exception(编码,环境,操作等异常)。

1
2
3
4
5
6
7
public abstract class VirtualMachineError{}
public class StackOverflowError{}
public class OutOfMemoryError{}
public class IllegalAccessError{}
public class NoClassDefFoundError{}
public class NoSuchFieldError{}
public class NoSuchMethodError{}

方法命名规范

表述获取

如果一个方法用于获取某个值,通常使用“get”作为其前缀

1
2
3
public String getUserName(){}
public List<Integer> getUserIds(){}
public User getOne(){}

表述查询

如果方法需要通过查询或筛选的方式获取某个数据,通常使用“find”/“query”作为其前缀

1
2
3
public List<Person> findOne(Integer id){}
public List<Integer> findAll(){}
public List<String> queryOrders(){}

表述条件

如果一个方法需要一些条件参数,则可以使用“by”/“with”等字符作为方法名中条件的连接符

1
2
3
public User findByUsername(String username){}
public List<Integer> getUserIdsWithState(boolean state){}
public List<User> findAllByUsernameOrderByIdDesc(String username){}

表述设置

如果一个方法是要设置,插入,修改,删除等操作,应该将对应的动词(set,insert,update,delete)作为其名词的前缀

1
2
3
4
public void setName(String name){}
public User insert(User user){}
public void update(User user){}
public void clearAll(){}

表述设置

如果一个方法用于获取某组数据的长度或数量,则该方法应该使用length或size命名;如果方法的返回值为布尔类型(Boolean),则该方法应该使用“is”或”has”作为前缀;

1
2
3
4
5
public long length(){}
public int size(){}
public boolean isOpen(){}
public boolean isNotEmpty(){}
public boolean hasLength(){}

如果方法用于将一种类型的数据转换为另一种数据数类型,则可以使用“to”作为前缀

1
2
3
public Set<Integer> mapToSet(HashMap<String,String> a){}
public UserDto convertTo(User user){}
public String toString(Object obj){}

变量命名规范

变量(Variable)命名包括参数名称,成员变量和局部变量。变量命名通常以小写字母开头,如果变量名由多个单词构成,则从第二个单词起首字母需要大写,在变量命名过程中,不建议使用“_”作为前缀或者单词之间的分割符号。

1
2
3
4
5
6
private String nickName;
private String mobileNumber;
private Long id;
private String username;
private Long orderId;
private Long orderItemId;

常量命名规范

一般地,常量名称采用全部大写的英文单词书写,如果常量名称由多个单词组成,则单词之间统一使用“_”进行分割

1
2
3
4
5
6
public static final String LOGIN_USER_SESSION_KEY = "current_login_user";
public static final int MAX_AGE_VALUE = 120;
public static final int DEFAULT_PAGE_NO = 1;
public static final long MAX_PAGE_SIZE = 1000;
public static final boolean HAS_LICENSE = false;
public static final boolean IS_CHECKED = false;

其它命名规范

数组命名

1
2
3
4
5
int[] array = new int[10];
int[] idArray ={1,2,3,4,5};
String[] nameArray = {"First","Yellow","Big"}
public List<String> getNameById(Integer[] ids){}
public List<String> getNameById(Integer...ids){}

表述复数或者集合

如果一个变量用于描述多个数据时,尽量使用单词的复数形式进行书写

1
2
3
Collection<Order> orders;
int[] values;
List<Item> items;

如果表述的是一个Map数据,则应使用“map”作为其后缀

1
2
Map<String,User> userMap;
Map<String,List<Object>> listMap;

泛型类

E表示Element,通常用在集合中;

ID用于表示对象的唯一标识符类型

T表示Type(类型),通常指代类;

K表示Key(键),通常用于Map中;

V表示Value(值),通常用于Map中,与K结对出现;

N表示Number,通常用于表示数值类型;

?表示不确定的Java类型;

X用于表示异常;

U,S表示任意的类型。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class HashSet<E> extends AbstractSet<E>{}
public class HashMap<K,V> extends AbstractMap<K,V>{}
public class ThreadLocal<T>{}
public interface Functor<T,X extends Throwable>{
T val() throws X;
}
public class Container<K,V>{
private K key;
private V value;
Container(K key,V value){
this.key = key;
this.value = value;
}
}
public interface BaseRepository<T,ID>{
T findById(ID id);
void update(T t);
List<T> findByIds(ID...ids);
}
public static <T> List<T> methodName(Class<T> clz){
List<T> dataList = getByClz(clz);
return dataList;
}

接口实现类

在通常情况下,建议接口实现类使用“Impl作为后缀”,不建议使用大写的“I”作为接口前缀

1
2
public interface OrderService{}
public class OrderServiceImpl implements OrderService{}

测试类和测试方法

测试类采用被测试业务模块名/被测试接口/被测试类+“Test”的方法进行书写,测试类中的测试函数采用“test”+用例操作_状态的组合方式进行书写

1
2
3
4
5
public class UserServiceTest{
public void testFindByUsernameAndPassword(){}
public void testUsernameExist_notExist(){}
public void testDeleteById_isOk(){}
}

×

纯属好玩

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

文章目录
  1. 1. Java命名
    1. 1.1. 包命名规范
    2. 1.2. 类命名规范
    3. 1.3. 接口命名规范
    4. 1.4. 异常类命名规范
    5. 1.5. 方法命名规范
      1. 1.5.1. 表述获取
      2. 1.5.2. 表述查询
      3. 1.5.3. 表述条件
      4. 1.5.4. 表述设置
      5. 1.5.5. 表述设置
    6. 1.6. 变量命名规范
    7. 1.7. 常量命名规范
    8. 1.8. 其它命名规范
      1. 1.8.1. 数组命名
      2. 1.8.2. 表述复数或者集合
      3. 1.8.3. 泛型类
      4. 1.8.4. 接口实现类
      5. 1.8.5. 测试类和测试方法
载入天数...载入时分秒...
,
字数统计:36.3k