枚举类和普通静态值类的区别

先来一个枚举来举例子

 1 /**
 2  * 
 3  */
 4 public enum  LogType {
 5     /**
 6      * 新增
 7      */
 8     ADD("36010100","ADD"),
 9     /**
10      * 修改
11      */
12     EDIT("36010101","EDIT"),
13     /**
14      * 删除
15      */
16     DEL("36010102","DEL"),
17     /**
18      * 查看
19      */
20     VIEW("--","VIEW"),
21     /**
22      * 默认无操作
23      */
24     NULL("","NULL"),
25     /**
26      * 回滚操作
27      */
28     ROLLBACK("36010103","ROLLBACK");
29     private String operateTypeKey;
30     private String operateType;
31     LogType(String key,String operateType){
32         this.operateTypeKey = key;
33         this.operateType = operateType;
34     }
35 
36     public String getOperateTypeKey() {
37         return operateTypeKey;
38     }
39 
40     public void setOperateTypeKey(String operateTypeKey) {
41         this.operateTypeKey = operateTypeKey;
42     }
43 
44     public String getOperateType() {
45         return operateType;
46     }
47 
48     public void setOperateType(String operateType) {
49         this.operateType = operateType;
50     }
51 
52     @Override
53     public String toString() {
54         return "AspectOperation{" +
55                 "operateTypeKey='" + operateTypeKey + '\'' +
56                 ", operateType='" + operateType + '\'' +
57                 '}';
58     }
59 }

在这个枚举当中可以看到例举了几种操作的类型,增加,修改,删除,查看,回滚的操作。

以及反编译之后的结果

 1 public enum LogType
 2 {
 3   ADD("36010100", "ADD"), 
 4 
 5   EDIT("36010101", "EDIT"), 
 6 
 7   DEL("36010102", "DEL"), 
 8 
 9   VIEW("--", "VIEW"), 
10 
11   NULL("", "NULL"), 
12 
13   ROLLBACK("36010103", "ROLLBACK");
14 
15   private String operateTypeKey;
16   private String operateType;
17 
18   private LogType(String key, String operateType) { this.operateTypeKey = key;
19     this.operateType = operateType; }
20 
21   public String getOperateTypeKey()
22   {
23     return this.operateTypeKey;
24   }
25 
26   public void setOperateTypeKey(String operateTypeKey) {
27     this.operateTypeKey = operateTypeKey;
28   }
29 
30   public String getOperateType() {
31     return this.operateType;
32   }
33 
34   public void setOperateType(String operateType) {
35     this.operateType = operateType;
36   }
37 
38   public String toString()
39   {
40     return "AspectOperation{operateTypeKey='" + this.operateTypeKey + '\'' + ", operateType='" + this.operateType + '\'' + '}';
41   }
42 }

可以看到在其构造函数当中,构造函数是private说明,其在创建的时候无法实例化枚举类型。但是他可以拥有自己的构造方法,一个私有值,和get set的方法,以及通过get方法返回你需要的,但是这边的set方法已经失去了它本身的意义,完全可以去除。

下面看一下静态值类

1 public class LogTypeStatic {
2     public final static String ADD="ADD";
3     public final static String Eidt="EDIT";
4     public final static String DEL="DEL";
5     public final static String NULL="NULL";
6     public final static String VIEW="VIEW";
7 }

静态值类很简单,罗列的几种出现的类型,简单的调用方式就不在这边赘述了。下面通过一个例子表示一下枚举类型在使用的时候的优势。

1 @Test
2     public void testLogType(){
3         LogType [] logType = LogType.values();
4         for(int i=0;i<logType.length;i++){
5             System.out.print(logType[i]);
6         }
7     }

枚举类有自己的可以遍历自己所有的值,当成一个集合来使用,在使用的时候如果有新的类型添加进来,直接在枚举类型当中进行修改,值需要修改这个类即可,其他设涉及到这边的类文件不需要修改,同时也可以映射到

将枚举的类型看成一个集合来继续处理,这样的处理方式比静态值的处理方式明显优越很多,易于扩展。方法之间的参数传递就通过枚举类来进行传递,而不通过String类型来进行传递,更加易于理解,在代码里面也有更多的含义。

转载于:https://www.cnblogs.com/binarysheep/p/5897277.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 反射: Class 类的实例表示正在运行的 Java 应用程序中的类和接口; 枚是一种类,注解(指的是注解Annotation)是一种接口; 每个数组都是 Class字节码类中的一个具体 对象 基本的 Java 类型(boolean、byte、char、short、int、long、float 和 double)和关键字 void 也表示为 Class 对象; 注意 : 1、 Class类 和它的实例的产生: Class的对象是已经存在的类型, 所以不能够直接new一个Class对象出来,是通过Class类中的一个方法获取到的。 例如:通过全限定路径类名 2、同一种类型不管通过什么方式得到Class的实例都是相等的;一个类型的字节码对象只有一份,在元空间。 3、Class的实例就看成是Java中我们学过的所有的数据类型在JVM中存在的一种状态(字节码对象) String.class int.class List.class int[].class 1.概念:通过一个全限定类名,获取字节码文件 2.作用: 1. 提高开发灵活度,提高程序的扩展性 2. 框架(提高开发效率的别人封装好的代码)底层都是使用反射技术。例如:Tomcat、Spring... 3. 缺点:破坏封装性,性能低下(以后,能不用反射技术就不用) 3. 使用:(重点) 1. 获取字节码文件 1. 1.1 Class clazz = Class.forName(全限定路径名) (最多使用)默认就是调用下面的方法 1.2 static 类<?> forName(String name, boolean initialize, ClassLoader loader) name:全限定路径名 initialize:表示是否初始化,默认是false loader:可以指定一个类加载器加载字节码文件 2. 全限定类名.class 3. 对象名.getClass() Class类中方法newInstance():创建当前字节码对象(只能调用无参且是public修饰的构造方法) 2. 根据字节码文件获取构造方法、普通方法、字段等 构造方法 Constructor[] constructors = clazz.getConstructors() 获取public修饰的构造方法数组 Constructor[] constructors = clazz.getDeclaredConstructors() 获取任意权限的所有造方法数组 Constructor constructor = clazz.getConstructor(Class 参数字节码)根据参数类型获取public修饰的指定的的构造方法 Constructor constructor = clazz.getDeclearConstructor(Class 参数字节码) 获取任意访问权限指定的构造方法 //通过构造方法对象去用构造方法创建对象 => 相当于new 一个对象 Object instance = constructor.newInstance(Object 实参);//可以创建任意访问权限的有参或者无参构造 普通方法 Method[] methods = clazz.getMethods() 获取public修饰的构造方法数组,有父类中的方法 Method[] methods = clazz.getDeclaredMethods() 获取任意访问权限所有造方法数组,并且都是自己的方法 Method method = clazz.getMethod(String methodName,Class... 参数字节码)根据方法名和参数类型获取指定的的方法 methodName:方法名 Class:形参类型。如果方法没有形参,则Class可变参数不用写 Method method = clazz.getDeclaredMethod(String methodName,Class... 参数字节码)根据方法名和参数类型获取指定的的方法 methodName:方法名 Class:形参类型。如果方法没有形参,则Class可变参数不用写 //通过普通方法对象调用执行方法 method.invoke(Object obj,Object... args); obj:对象。如果是对象的方法,就传入一个当前字节码创建的对象,如果是static方法,则写null args:就是具体实参 字段 Field[] fields = clazz.getFields() 获取public修饰的字段 Field[] fields = clazz.getDeclaredFields() 获取任意权限所有字段 Field field = clazz.getDeclaredField(String fieldName) 根据字段名获取任意访问权限的指定字段 Field field = clazz.Field(String fieldName)根据字段名获取public的指定字段 //通过当前的字段对象,给某一个字段赋 field.get(Object obj);//如果是属于非static,就传入一个对象,如果是静态的,就传入null obj:对象 field.set(Object obj, Object value);//如果是属于非static,就传入一个对象,如果是静态的,就传入null obj:对象 value: String getName() 获取全限定类名(全限定,包含包名) Class类中方法 String getSimpleName() 获取类名简称 Class类中方法 Package getPackage() 获取包名 Class类中方法 T newInstance() 根据当前字节码创建对应的对象 Class类中方法 注意: 1. Class类中方法newInstance():创建当前字节码对象(只能调用无参且是public修饰的构造方法) 2. Constructor类中方法newInstance(Object 实参);//可以创建任意访问权限的有参或者无参构造 3. 私有化方法、字段、构造方法都必须破坏封装才能使用: public void setAccessible(boolean flag) true表示破坏封装,false是不破坏 是哪个private修饰的方法、字段、构造方法需要执行,就需要用这个对象破坏哪一个的封装 例如: //获取cn.itsource.reflect.User字节码文件 Class<?> clazz = Class.forName("cn.itsource.reflect.User"); //获取User的有String参构造 Constructor<?> constructor = clazz.getConstructor(String.class); //调用有参String构造,创建一个User对象 Object newInstance = constructor.newInstance("某文"); //获取private修饰的方法:testPrivate Method method2 = clazz.getDeclaredMethod("testPrivate"); method2.setAccessible(true);//破坏普通方法Method封装 //破坏封装后就可以执行了 Object invoke2 = method2.invoke(newInstance);//没有形参就不用写 System.out.println(invoke2); 4. 调用static方法、字段: 例如: Field field = clazz.getDeclaredField("country");//获取任意访问权限静态变量country field.set(null, "中国");//因为字段country是static修饰,所以不用对象调用,就传入null。字段country赋:中文 Object object = field.get(null);//字段country取 System.out.println(object); 2. 注解: 1.概念: 就是一个标签,有标签后,就具有某一些标签的特性。 本质就是跟类、接口、枚平级的新结构 2.作用: 1. 帮助程序员校验代码 2. 可以提高开发效率和程序的扩展性 @Test @Before @After 3. 可以生成文档说明 api 操作步骤: 1.选中项目/代码,右键选中Export 2.输入Javadoc 3.第一个next(可以设置生成文档注释的目录),第二个next,设置字符集 如果是UTF-8编码,且有中文,请输入-encoding UTF-8 -charset UTF-8 4. 勾选一个生成完毕后,直接通过浏览器打开的选项 5. finish 3.使用:(重点) 1. 使用jdk或者别人定义好的标签 @ + 注解的名称 -- 比如@Override ->注解 2. 使用自定义的标签 1.JDK的元注解:就是专门用来声明其他注解的注解 作用:通过元注解了解其他注解的使用特点,还可以自定义注解 2.元注解: 1. @Target @Target 作用 用来限制被修饰注解的使用范围,即注解可以在类的哪些成员上使用 @Target 取使用ElementType.() 1. CONSTRUCTOR:可以在构造器上使用注解 2. FIELD:可以在字段上使用注解 3. LOCAL_VARIABLE:可以在局部变量上使用注解 4. METHOD:可以在普通方法上使用注解 5. PACKAGE:可以在包上使用注解 6. PARAMETER:可以在参数列表上使用注解 7. TYPE:可以在类、接口(包括注解类型) 或enum上使用注解 例如:@Target(ElementType.METHOD)//意味着@Override只能在普通方法上使用 public @interface Override { } 2. @Retention

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值