【Java提高】---枚举的应用
枚举
一、枚举和静态常量的区别
讲到枚举我们首先思考,它和public static final String 修饰的常量有什么不同。
我举枚举的两个优点:
1. 保证了类型安全:调用者无法随意传一个 int或者String 等值;
2.代码可读性非常高;
举个例子:
在实际编程中,往往存在着这样的“数据集”,它们的数值在程序中是稳定的,而且“数据集”中的元素是有限的。例如春夏秋冬四个数据元素组成了四季的“数据集”。你写了方法
get(String season),输入的类型只能是String类型,同时要String只能是(春、夏。秋。冬)。
这个时候。你写四个字符串常量
public class Common {
public static final String SPRING="春";
public static final String SEASON="夏";
public static final String SUMMER="秋";
public static final String AUTUMN="冬";
}
在get方法里放入get(Common.SEASON),确实是把"春",放进去了,但是这个时候你会发现这里面有一个隐患,你get(String season),毕竟放入的是String类型的,如果新同事或者不知情的同事,
不知道这个方法里只能放“春、夏、秋、冬”,它放了个其期它字符串比如get("小小“),这个时候,在编译期它是不会报错的,只有运行之后,才发现错了。 为了防止上面的隐患,枚举出现了
public enum Season {
SPRING("春"),
SUMMER("夏"),
AUTUMN("秋"),
WINTER("冬");
.....
}
这个时候,我们修改get方法的传参,改成get(Season season) 这个时候加入get(Season.SPRING),这就能保证传入的参数只能是这几个。
二、理解枚举
首要我们要明确,其实枚举也是个class类,我写个枚举来理解。
//我们把枚举当做一个普通类
public enum Season {
SPRING(1,"春"),
SUMMER(2,"夏" ),
AUTUMN(3,"秋" ),
WINTER(4,"冬"); //这里最后一个一定要分号,否则报错 /*我们可以理解成
*public static final Season SPRING = new Season(1,春);
*public static final Season SUMMER = new Season(2,夏);
*public static final Season AUTUMN = new Season(3,秋);
*public static final Season WINTER = new Season(4,冬);
*既然是对象,那下面就很好理解了
*/ /*
* 1.上面对象里放了两个参数,那下面就肯定要有这个类型的构造函数
* 2.这里是private,因为不能在被new对象了
*/
private Season(int code,String name) {
this.name = name;
this.code = code;
} //对象的属性
private String name;
private int code; //获取对象属性的方法
public String getName() {
return this.name;
}
public String getCode() {
return this.name;
} //通过code获得对象,我们就可以获得对象的其它属性
public static Season decode(int code) {
Season season = null;
for (Season type : Season.values()) {
if (type.code==code) {
season = type;
break;
}
}
return season;
} //重新toString方法
public String toString() {
return this.name;
}
}
上面这个例子,就很好解释了枚举,它和普通类没什么区别,只是用另一种写法创建了几个有属性的对象,这也必须写这样有属性的构造函数,仅此而已。
这里顺便列举下枚举的一些特点:
1.它不能有public的构造函数,这样做可以保证客户代码没有办法新建一个enum的实例。
2. 枚举不能在继承其它类了,因为它默认继承了java.lang.Enum
3. 常量值地址唯一,可以用==直接对比,性能会有提高.
4.Enum还提供了values方法,这个方法使你能够方便的遍历所有的枚举值。
5.Enum还有一个oridinal的方法,这个方法返回枚举值在枚举类种的顺序,这个顺序根据枚举值声明的顺序而定。
三、枚举的常见用法
第一种:switch运用
先建一个枚举:
public enum Common { INSERT,
MODIFY,
DELETE
}
//因为这里是无参的对象,所以可以用系统默认的构造函数。也不用写属性和方法。
在写实现代码
public class CommonUtils { public static void getType(Common common){
Common c=common;
switch(c)
{
case INSERT:
System.out.println("进行插入操作");
break;
case MODIFY:
System.out.println("进行修改操作");
break;
case DELETE:
System.out.println("进行删除操作");
break;
} }
public static void main(String[] args) {
getType(Common.DELETE); //后台输出:进行删除操作
}
}
第二种用法,通过key值获得value值获取其它值
枚举类
public enum Season {
SPRING(1,"春","春天放风筝"),
SUMMER(2,"夏","夏天去游泳"),
AUTUMN(3,"秋","秋天去秋游"),
WINTER(4,"冬","冬天吃火锅"); private Season(int code,String name,String bz) {
this.code = code;
this.name = name;
this.bz=bz;
} private int code;
private String name;
private String bz; public static Season decode(int code) {
Season season = null;
for (Season type : Season.values()) {
if (type.code==code) {
season = type;
break;
}
}
return season;
} public int getCode() {
return code;
} public String getName() {
return name;
} public String getBz() {
return bz;
} }
测试类
好了,就写这么多,以后有需要会更深入了解。
想的太多,做的太少,中间的落差就是烦恼,要么去做,要么别想 少尉【18】
【Java提高】---枚举的应用的更多相关文章
- Java提高篇(三二)-----List总结
前面LZ已经充分介绍了有关于List接口的大部分知识,如ArrayList.LinkedList.Vector.Stack,通过这几个知识点可以对List接口有了比较深的了解了.只有通过归纳总结的知识 ...
- java提高篇(三十)-----Iterator
迭代对于我们搞Java的来说绝对不陌生.我们常常使用JDK提供的迭代接口进行Java集合的迭代. Iterator iterator = list.iterator(); while(iterator ...
- java提高篇---Iterator
迭代对于我们搞Java的来说绝对不陌生.我们常常使用JDK提供的迭代接口进行Java集合的迭代. Iterator iterator = list.iterator(); while(iterator ...
- Java提高篇(三二)-----List总结
前面LZ已经充分介绍了有关于List接口的大部分知识,如ArrayList.LinkedList.Vector.Stack,通过这几个知识点能够对List接口有了比較深的了解了.仅仅有通过归纳总结的知 ...
- Java提高合集(转载)
转载自:http://www.cnblogs.com/pony1223/p/7643842.html Java提高十五:容器元素比较Comparable&Comparator深入分析 JAVA ...
- Java提高篇——对象克隆(复制)
假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(boolean,char,byte,short, ...
- Java提高篇(三三)-----Map总结
在前面LZ详细介绍了HashMap.HashTable.TreeMap的实现方法,从数据结构.实现原理.源码分析三个方面进行阐述,对这个三个类应该有了比较清晰的了解,下面LZ就Map做一个简单的总结. ...
- Java提高篇(三一)-----Stack
在Java中Stack类表示后进先出(LIFO)的对象堆栈.栈是一种非常常见的数据结构,它采用典型的先进后出的操作方式完成的.每一个栈都包含一个栈顶,每次出栈是将栈顶的数据取出,如下: Stack通过 ...
- java提高篇(二九)-----Vector
在java提高篇(二一)-–ArrayList.java提高篇(二二)-LinkedList,详细讲解了ArrayList.linkedList的原理和实现过程,对于List接口这里还介绍一个它的实现 ...
- Java提高篇(二八)------TreeSet
与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.在<Java提高篇(二七)-----TreeMap>中LZ详细讲解了TreeMap实现机制,如果 ...
随机推荐
- Structural Inference of Hierarchies in Networks(网络层次结构推断)
Structural Inference of Hierarchies in Networks(网络层次结构推断) 1. 问题 层次结构是一种重要的复杂网络性质.这篇文章给出了层次结构的精确定义,给出 ...
- ArcGIS API for JavaScript 4.2学习笔记[24] 【IdentifyTask类】的使用(结合IdentifyParameters类)(第七章完结)
好吧,我都要吐了. 接连三个例子都是类似的套路,使用某个查询参数类的实例,结合对应的Task类,对返回值进行取值.显示. 这个例子是Identify识别,使用了TileLayer这种图层,数据来自Se ...
- Equilibrium point
Given an array A your task is to tell at which position the equilibrium first occurs in the array. E ...
- bzoj 4198: [Noi2015]荷马史诗
Description 追逐影子的人,自己就是影子. --荷马 Allison 最近迷上了文学.她喜欢在一个慵懒的午后,细细地品上一杯卡布奇诺,静静地阅读她爱不释手的<荷马史诗>.但是由& ...
- ValueError: too many values to unpack (expected 2)
记录下总是码错的地方 for key,value in final_table:#final_table is a dict 然后报错 File "./count_co_Mty_read_n ...
- MySQL 数据类型和约束(外键是重点🙄)
数据类型 1. 数字(默认都是由符号,宽度表示的是显示宽度,与存储无关).tinyint 括号里指定宽度 七位2进制数最大数就是2**7 -1=127 最小是-128 验证: create tabel ...
- 小白的Python之路 day5 python模块详解及import本质
一.定义 模块:用来从逻辑上组织python代码(变量,函数,类,逻辑:实现一个功能) 本质就是.py结尾的python文件(文件名:test.py,对应的模块名:test) 包:用来从逻辑上组织模块 ...
- extjs Proxy
我们先来看看Extjs非常绚丽的Grid,其功能包括显示数据列表,修改.删除,分页,排序等功能. Grid组件用来显示Store中的数据.Store可以看做是Model实例的集合.Grid仅关心如 ...
- java多线程(八)-死锁问题和java多线程总结
为了防止对共享受限资源的争夺,我们可以通过synchronized等方式来加锁,这个时候该线程就处于阻塞状态,设想这样一种情况,线程A等着线程B完成后才能执行,而线程B又等着线程C,而线程C又等着线程 ...
- 漫话JavaScript与异步·第三话——Generator:化异步为同步
一.Promise并非完美 我在上一话中介绍了Promise,这种模式增强了事件订阅机制,很好地解决了控制反转带来的信任问题.硬编码回调执行顺序造成的"回调金字塔"问题,无疑大大提 ...