• 枚举类(enum)

其实我们使用到枚举的地方还是很多的,其实我们可以完全人工的来实现枚举的功能。比如说我现在手里的项目我就是自己实现的枚举,说白了,枚举就是一个类的多例模式。

1,使用enum声明,默认直接继承了java.lang.Enum类,而不是Object类;

2,枚举类的对象是固定的,实例个数有限,枚举对象后可以跟();跟着()的意思就是在调用相关的构造器,要是不写的话就是在调用默认的构造器。

3,枚举元素必须位于枚举类体中的最开始部分,枚举元素后要有分号与其他成员分隔;

4,枚举类的构造方法的权限修饰符默认是private;自己在定义枚举类的时候也要限定修饰符为private的。

5,一旦枚举对象后面加上{},那么该对象实际是枚举匿名内部类对象;一般在传入这个匿名内部类的时候都要实现里面的抽象方法。

6,下面这2个ipa比较重要:所有枚举类都提供一个静态的values()方法(返回该枚举类所有对象组成的数组),便于遍历所有枚举对象;

所有枚举类都提供一个静态的valueOf(String name)方法, 返回枚举类中对象名等于 name的对象。



/**
*
* @version 1L
* @author LinkinPark
* @since 2014-11-2
* @motto 梦似烟花心似水,同学少年不言情
* @desc ^使用enum定义,非抽象的枚举类默认会使用final修饰,因此枚举类不能派生子类
*/
public enum SeasonEnum { //在这里要列出4个枚举实例
//注意了:枚举类的所有实例必须在枚举类的第一行显式列出,否则这个枚举永远不能产生实例
SPRING,SUMMER,FALL,WINTER;//默认添加 public static final //枚举类的构造器还能使用private访问控制符,默认也是使用private修饰的构造器
private SeasonEnum(){ } public static void test(SeasonEnum s){
switch(s){
case SPRING:
System.out.println("春天。。。");
break;
case SUMMER:
System.out.println("夏天。。。");
break;
case FALL:
System.out.println("秋天。。。");
break;
case WINTER:
System.out.println("冬天。。。");
break;
}
} public static void main(String[] args) {
for(SeasonEnum s:SeasonEnum.values()){
System.out.println(s);
} SeasonEnum.test(SeasonEnum.SPRING);
} }

  • Java5开始出现枚举:

<1>.私有的构造方法

<2>.每个元素分别用一个公有的静态成员变量表示,枚举类的对象是固定的,实例个数有限。

<3>.枚举的直接父类java.lang.Enum;

<4>.枚举就相当于一个类,其中也可以定义构造方法、成员变量、普通方法和抽象方法。

<5>.枚举元素必须位于枚举体中的最开始部分,枚举元素列表的后要有分号与其他成员分隔。

<6>.把枚举中的成员方法或变量等放在枚举元素的前面,编译器报告错误。

<7>.枚举只有一个成员时,就可以作为一种单例的实现方式。

<8>.枚举元素有大括号对时,此时属性是枚举类的匿名内部类对象。(查看编译后的class文件)

<9>.所有枚举类都提供一个静态的values()方法(返回该枚举类所有对象组成的数组),便于遍历所有枚举对象;

<10>.Enum常见方法:

String name();// 返回枚举实例名称;

int ordinal();// 返回枚举实例在枚举类中的索引,从0开始;

String toString();// 返回枚举对象的"自我描述";(看源代码)

<11>.在switch语句中使用枚举对象;

<12>.枚举类的构造方法;

<13>.枚举类覆写接口抽象方法的两种方式:

a.在枚举类中实现接口抽象方法;

b.在枚举匿名内部类对象中实现接口抽象方法;

public enum Gender {

    MALE("男","这里是男的"),FEMALE("女","这里是女的");

    //其实也可以不用枚举的 ,定义一个抽象类继承Enum,之后再继承这个抽象类,定义2个方法分别来获得下面的2个属性
//public static final Gender MALE = new Gender("男","这里是男的"); private final String name; private final String lable; private Gender(String name,String lable){
this.name = name;
this.lable = lable;
} public String getName(){
return this.name;
} public String getLable(){
return this.lable;
} //可以到的上面构造器中传入的2个字符串的
public static void main(String[] args) {
System.out.println(Gender.MALE.getName());
System.out.println(Gender.MALE.getLable());
} }

  • 枚举类实现接口

枚举类覆写接口抽象方法的两种方式:

1,在枚举类中实现接口的抽象方法;

2,在枚举匿名内部类中实现接口的抽象方法;



//实现接口的枚举
public enum Linkin implements GenderDesc{ MALE("男"),FEMALE("女");
private String name; @Override
public void show() {
System.out.println("这里是一个用于定义性别属性的方法。。。");
} private Linkin(String name){
this.name = name;
} public String getName(){
return this.name;
} } interface GenderDesc{
void show();
}
<pre name="code" class="java">//实现接口的枚举
//让每个枚举类在调用方法时呈现出不同的行为方式
public enum Linkin implements GenderDesc{ //MALE FEMALE 实际上是Linkin匿名子类的实例 MALE("男"){
public void show() {
System.out.println("这里创建的是男的实例。。。");
}
},FEMALE("女"){
public void show() {
System.out.println("这里创建的是女的实例。。。");
}
};
private String name; private Linkin(String name){
this.name = name;
} public String getName(){
return this.name;
} } interface GenderDesc{
void show();
}

  • 包含抽象方法的枚举类
public enum Linkin{
PLUS{
public double eval(double x,double y){
return x+y;
}
},
MINUS{
public double eval(double x,double y){
return x-y;
}
},
TIMES{
public double eval(double x,double y){
return x*y;
}
},
DIVIDE{
public double eval(double x,double y){
return x/y;
}
}; abstract public double eval(double x,double y); public static void main(String[] args) {
System.out.println(Linkin.PLUS.eval(1, 1));
System.out.println(Linkin.MINUS.eval(1, 1));
System.out.println(Linkin.TIMES.eval(1, 1));
System.out.println(Linkin.DIVIDE.eval(1, 1));
}
}
  • 枚举类的单例模式

使用枚举类来实现单例模式的好处是这样非常简洁,并且无偿地提供了序列化机制,绝对防止多次实例化,即使是在面对复杂的序列化或者反射攻击的时候。

——来自《Effective Java》(作者:Josh Bloch)

enum Singleton {
INSTANCE;//唯一实例 public void print(){
System.out.println("使用enum实现单例模式");
}
public static Singleton getInstance(){
return INSTANCE;
}
}





linkin大话面向对象--枚举的更多相关文章

  1. linkin大话面向对象--类和对象

    我们每天在撸码,那么我们在敲什么东西呢?明显的我们在写类,写一个类,写一个接口,写某个接口里面写一些属性,在某个类里面写一个方法,然后以一个对象调用方法,对于j2ee来讲的话,可能还会写一些jsp,静 ...

  2. linkin大话面向对象--闭包和回调

      先来理解2个概念:闭包和回调   什么是闭包? 闭包是一个可调用的对象,它记录了一些信息,这些信息来自于创建他的作用域.通过这个定义,可以看出内部类是面向对象的闭包,因为他不仅包含了外部类对象的信 ...

  3. linkin大话面向对象--多态

    java引用变量有2个类型,一个是编译时类型,一个是运行时类型: 编译时类型:声明的类型,把它看做是什么东西 运行时类型:真正的类型,实际上指的是什么东西 如果编译时类型和运行时类型不同,就出现多态. ...

  4. linkin大话面向对象--GC和jar包

    GC java的垃圾回机制是java语言的重要机制之一.当程序创建对象,数组等引用类型实体时,系统都会在堆内存中为之分配一块内存区,对象就保存在这块内存区中.当这块内存不再被任何变量引用时,这块内存就 ...

  5. linkin大话面向对象--内部类

    内部类说白了就是类中有类 内部类:嵌套类 外部类:宿主类 内部类主要有以下作用:记住了3个字:多继承... 1,内部类提供了更好的封装,可以把内部类隐藏在外部类中,不允许同一个包中的其他类访问该类. ...

  6. linkin大话面向对象--接口

    接口(interface)的概念,掌握接口很重要,以后所有的编程都要面向接口编程.其实接口的内涵就7个字:规范和实现分离. 抽象类是从多个类中抽象出来的模板,若要将这种抽象进行得更彻底,就得用到一种特 ...

  7. linkin大话面向对象--包装类

    Java提倡的万物皆对象,但是数据类型的划分出现了基本数据类型和引用数据类型,那么我们怎么能把基本数据类型称为对象呢? 基本数据类型 包装类 byte Byte short Short int Int ...

  8. linkin大话面向对象--java关键字

    java中的关键字有以下几个,他们不能作任何其它的用途. 发现没,java中的关键字全是小写,java是严格区分大小写的. abstract  default  null  synchronized ...

  9. linkin大话面向对象--初始化块

    java使用构造器来对单个对象进行初始化操作,使用构造器先完成整个java对象的状态初始化,然后将java对象返回给程序,从而让整个java对象的信息更加完整.与构造器作用非常类似的是初始化块,它也可 ...

随机推荐

  1. 三种ajax上传文件方法

    1.  XMLHttpRequest(原生ajax) <input class="file" type="file" id="fafafa&qu ...

  2. java.lang.Class类中的某些方法

    反射的代码会经常遇到,Class类中方法真的多,且用的少,大多用在底层源码这块,既然看到了,就记录一下吧,说不定以后厉害了,自己封装框架,haha getComponentType()方法: Syst ...

  3. MacBook安装Win10

    // 这是一篇导入进来的旧博客,可能有时效性问题. (一)  确认你的机型 以下机型支持: ü  安装64 位版本Win10 ü  不使用U盘安装Windows l  MacBook(Retina 显 ...

  4. Java与算法之(10) - 希尔排序

    希尔排序是插入排序的一种,是直接插入排序的改进版本. 对于上节介绍的直接插入排序法,如果数据原来就已经按要求的顺序排列,则在排序过程中不需要进行数据移动操作,即可得到有序数列.但是,如果最初的数据是按 ...

  5. 【Java学习笔记之十】Java中循环语句foreach使用总结及foreach写法失效的问题

    foreach语句使用总结 增强for(part1:part2){part3}; part2中是一个数组对象,或者是带有泛性的集合. part1定义了一个局部变量,这个局部变量的类型与part2中的对 ...

  6. 用gcc编译c语言程序以及其编译过程

    对于初学c语言编程的我们来说,学会如何使用gcc编译器工具,对理解c语言的执行过程,加深对c语言的理解很重要!!! 1.预编译 --> 2.编译 --> 3.汇编 --> 4.链接- ...

  7. Dora.Interception, 一个为.NET Core度身打造的AOP框架:不一样的Interceptor定义方式

    相较于社区其他主流的AOP框架,Dora.Interception在Interceptor提供了完全不同的编程方式.我们并没有为Interceptor定义一个接口,正是因为不需要实现一个预定义的接口, ...

  8. [国嵌攻略][149][Yaffs2文件系统应用]

    嵌入式系统自启动 MTD技术通过把Nand FLash划分成bootloader分区,Linux kernel分区和file system分区来达到自启动的效果. 配置和编译内核 1.配置Linux内 ...

  9. [国嵌攻略][103][Linux内核模块基础]

    什么是内核模块 Linux内核的整体结构非常庞大,其中包含的组件也非常多,如何使用这些组件.一种方式是把所有的组件都编译进内核文件,即zImage或bzImage,但这样会导致一个问题,占用内存过多. ...

  10. 国寿e店/人寿云参会云助理,不去公司就能刷脸考勤打卡?

    自从2017年3月平安保险公司实行E行销打卡考勤以来,保险增员迅猛增加,保险业绩也随之水涨船高.年底开始中国人寿保险也陆续开始实行app考勤,有些需要连接公司指定WiFi,或在指定地点方可打卡考勤.不 ...