- 浏览: 468813 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (146)
- Maven (3)
- Quartz (10)
- Hessian (3)
- JDK (42)
- eclipse (4)
- 设计思想 (6)
- XML (8)
- JavaMail (1)
- Spring (11)
- mina (1)
- HsqlDb (1)
- Cache (2)
- Tool (6)
- 心情 (5)
- JQuery (0)
- Hadoop (5)
- Hbase (3)
- 自动构建 (7)
- JNDI (0)
- 代码赏析 (5)
- Oracle (1)
- Excel (4)
- Effective Java (5)
- JAXB (4)
- fdafasdf (1)
- ccc (0)
- web (3)
- concurrent (1)
- CVS (1)
- eclipse plugin (2)
- Apache (10)
最新评论
-
chxiaowu:
nice!
Quartz实现固定执行次数 -
zxjlwt:
学习了。http://surenpi.com
自定义ClassLoader -
kadlly:
public static final Logger log ...
Hessian 权限认证 -
spring_springmvc:
java程序语言学习教程 地址http://www.zuida ...
Java-Final -
liushuiwuyan:
[img][/img]
设计模式-单例
Enum
一般用来表示一组相同类型的常量.比如性别,月份,颜色等.
1.声名Enum
Public enum Sex{ MAN, WOMAN } Public enum Color{ RED,BLUE,GREEN,BLACK }
2. 使用Enum
JavaEnum简单的用法一般用于代表一组常量,可用来代码一类相同类型的常量值.[常量一般大写,注意规范]
package org.yclframework.auth.test.dao.ibatis; public enum Sex { MAN("男"),WOMAN("女"); private final String sex; private Sex(String sex){ this.sex=sex; } public String getSex(){ return sex; } public static void print(String sex){ if(sex.equals("MAN")){ System.out.println(Sex.MAN.getSex()); }else if(sex.equals("WOMAN")){ System.out.println(Sex.WOMAN.getSex()); } } }
建立测试类如下:
package org.yclframework.auth.test.dao.ibatis; public class Testenum { /** * @param args */ public static void main(String[] args) { for(Sex sex:Sex.values()){ System.out.println(sex.getSex()); } Sex.print("MAN"); } }
这个Enum类到底和正常的类有何区别,请看以下分解:
// Compiled from Sex.java (version 1.5 : 49.0, super bit) // Signature: Ljava/lang/Enum<Lorg/yclframework/auth/test/dao/ibatis/Sex;>; public final enum org.yclframework.auth.test.dao.ibatis.Sex { //enum是最终类,不可改变的. // Field descriptor #6 Lorg/yclframework/auth/test/dao/ibatis/Sex; public static final enum org.yclframework.auth.test.dao.ibatis.Sex MAN;//声名自身变量 // Field descriptor #6 Lorg/yclframework/auth/test/dao/ibatis/Sex; public static final enum org.yclframework.auth.test.dao.ibatis.Sex WOMAN;//声名自身变量 // Field descriptor #9 Ljava/lang/String; private final java.lang.String sex;//声名一个string类型 // Field descriptor #11 [Lorg/yclframework/auth/test/dao/ibatis/Sex; private static final synthetic org.yclframework.auth.test.dao.ibatis.Sex[] ENUM$VALUES;//声名一个数组 // Method descriptor #13 ()V // Stack: 5, Locals: 0 static {}; 0 new org.yclframework.auth.test.dao.ibatis.Sex [1]//创建一个sex对象 3 dup制栈顶数值并将复制值压入栈顶 4 ldc <String "MAN"> [15] 将String型常量值从常量池中推送至栈顶 6 iconst_0 将int型0推送至栈顶 7 ldc <String "男"> [16] 将String型常量值从常量池中推送至栈顶 9 invokespecial org.yclframework.auth.test.dao.ibatis.Sex(java.lang.String, int, java.lang.String) [18]调用Sext的方法,这个方法参数为String ,int,String 12 putstatic org.yclframework.auth.test.dao.ibatis.Sex.MAN : org.yclframework.auth.test.dao.ibatis.Sex [22] 为指定的类的静态域赋值 15 new org.yclframework.auth.test.dao.ibatis.Sex [1] 18 dup 19 ldc <String "WOMAN"> [24] 21 iconst_1 22 ldc <String "女"> [25] 24 invokespecial org.yclframework.auth.test.dao.ibatis.Sex(java.lang.String, int, java.lang.String) [18] 27 putstatic org.yclframework.auth.test.dao.ibatis.Sex.WOMAN : org.yclframework.auth.test.dao.ibatis.Sex [27] 30 iconst_2 31 anewarray org.yclframework.auth.test.dao.ibatis.Sex [1] 34 dup 35 iconst_0 36 getstatic org.yclframework.auth.test.dao.ibatis.Sex.MAN : org.yclframework.auth.test.dao.ibatis.Sex [22] 获取指定类的静态域,并将其值压入栈顶 39 aastore 40 dup 41 iconst_1 42 getstatic org.yclframework.auth.test.dao.ibatis.Sex.WOMAN : org.yclframework.auth.test.dao.ibatis.Sex [27] 45 aastore 46 putstatic org.yclframework.auth.test.dao.ibatis.Sex.ENUM$VALUES : org.yclframework.auth.test.dao.ibatis.Sex[] [29] 49 return Line numbers: [pc: 0, line: 4] [pc: 30, line: 3] // Method descriptor #21 (Ljava/lang/String;ILjava/lang/String;)V // Stack: 3, Locals: 4 private Sex(java.lang.String arg0, int arg1, java.lang.String sex); 0 aload_0 [this] 1 aload_1 2 iload_2 3 invokespecial java.lang.Enum(java.lang.String int,) [33] 6 aload_0 [this] 7 aload_3 [sex] 8 putfield org.yclframework.auth.test.dao.ibatis.Sex.sex : java.lang.String [36] 11 return Line numbers: [pc: 0, line: 8] [pc: 6, line: 9] [pc: 11, line: 10] Local variable table: [pc: 0, pc: 12] local: this index: 0 type: org.yclframework.auth.test.dao.ibatis.Sex [pc: 0, pc: 12] local: sex index: 3 type: java.lang.String // Method descriptor #40 ()Ljava/lang/String; // Stack: 1, Locals: 1 public java.lang.String getSex(); 0 aload_0 [this] 1 getfield org.yclframework.auth.test.dao.ibatis.Sex.sex : java.lang.String [36] 4 areturn Line numbers: [pc: 0, line: 13] Local variable table: [pc: 0, pc: 5] local: this index: 0 type: org.yclframework.auth.test.dao.ibatis.Sex // Method descriptor #42 (Ljava/lang/String;)V // Stack: 2, Locals: 1 public static void print(java.lang.String sex); 0 aload_0 [sex] 1 ldc <String "MAN"> [15] 3 invokevirtual java.lang.String.equals(java.lang.Object) : boolean [43] 6 ifeq 24 9 getstatic java.lang.System.out : java.io.PrintStream [49] 12 getstatic org.yclframework.auth.test.dao.ibatis.Sex.MAN : org.yclframework.auth.test.dao.ibatis.Sex [22] 15 invokevirtual org.yclframework.auth.test.dao.ibatis.Sex.getSex() : java.lang.String [55] 18 invokevirtual java.io.PrintStream.println(java.lang.String) : void [57] 21 goto 45 24 aload_0 [sex] 25 ldc <String "WOMAN"> [24] 27 invokevirtual java.lang.String.equals(java.lang.Object) : boolean [43] 30 ifeq 45 33 getstatic java.lang.System.out : java.io.PrintStream [49] 36 getstatic org.yclframework.auth.test.dao.ibatis.Sex.WOMAN : org.yclframework.auth.test.dao.ibatis.Sex [27] 39 invokevirtual org.yclframework.auth.test.dao.ibatis.Sex.getSex() : java.lang.String [55] 42 invokevirtual java.io.PrintStream.println(java.lang.String) : void [57] 45 return Line numbers: [pc: 0, line: 17] [pc: 9, line: 18] [pc: 24, line: 19] [pc: 33, line: 20] [pc: 45, line: 23] Local variable table: [pc: 0, pc: 46] local: sex index: 0 type: java.lang.String // Method descriptor #63 ()[Lorg/yclframework/auth/test/dao/ibatis/Sex; // Stack: 5, Locals: 3 public static org.yclframework.auth.test.dao.ibatis.Sex[] values();//声名values数组 0 getstatic org.yclframework.auth.test.dao.ibatis.Sex.ENUM$VALUES : org.yclframework.auth.test.dao.ibatis.Sex[] [29] 3 dup 4 astore_0 5 iconst_0 6 aload_0 7 arraylength 8 dup 9 istore_1 10 anewarray org.yclframework.auth.test.dao.ibatis.Sex [1] 13 dup 14 astore_2 15 iconst_0 16 iload_1 17 invokestatic java.lang.System.arraycopy(java.lang.Object, int, java.lang.Object, int, int) : void [64] 20 aload_2 21 areturn Line numbers: [pc: 0, line: 1] // Method descriptor #69 (Ljava/lang/String;)Lorg/yclframework/auth/test/dao/ibatis/Sex; // Stack: 2, Locals: 1 public static org.yclframework.auth.test.dao.ibatis.Sex valueOf(java.lang.String arg0); 0 ldc <Class org.yclframework.auth.test.dao.ibatis.Sex> [1] 2 aload_0 3 invokestatic java.lang.Enum.valueOf(java.lang.Class, java.lang.String) : java.lang.Enum [70] 6 checkcast org.yclframework.auth.test.dao.ibatis.Sex [1] 9 areturn Line numbers: [pc: 0, line: 1] }
看这个Sex类,我明明很简单的几个方法,为什么会有这么多的解析过程:
private static final synthetic org.yclframework.auth.test.dao.ibatis.Sex[] ENUM$VALUES;//声名一个数组 MAN("男")既然解析成: new org.yclframework.auth.test.dao.ibatis.Sex [1]//创建一个sex对象 dup制栈顶数值并将复制值压入栈顶 ldc <String "MAN"> [15] 将String型常量值从常量池中推送至栈顶 iconst_0 将int型0推送至栈顶 ldc <String "男"> [16] 将String型常量值从常量池中推送至栈顶 invokespecial org.yclframework.auth.test.dao.ibatis.Sex(java.lang.String, int, java.lang.String) [18]调用Sex的方法,这个方法参数为String ,int,String putstatic org.yclframework.auth.test.dao.ibatis.Sex.MAN : org.yclframework.auth.test.dao.ibatis.Sex [22] 为指定的类的静态域赋值
JVM自动将MAN("男")解析为字符串”MAN”,int下标 0,字符串”男”,再自动invoke Sex(String,int,String)Sex(“MAN”,0,”男”);
然后在后面又声名了一个数组,并把他们添加进去.
31 anewarray org.yclframework.auth.test.dao.ibatis.Sex [1] 34 dup 35 iconst_0 36 getstatic org.yclframework.auth.test.dao.ibatis.Sex.MAN : org.yclframework.auth.test.dao.ibatis.Sex [22] 获取指定类的静态域,并将其值压入栈顶 39 aastore 40 dup 41 iconst_1 42 getstatic org.yclframework.auth.test.dao.ibatis.Sex.WOMAN : org.yclframework.auth.test.dao.ibatis.Sex [27] 45 aastore 46 putstatic org.yclframework.auth.test.dao.ibatis.Sex.ENUM$VALUES : org.yclframework.auth.test.dao.ibatis.Sex[] [29] 49 return
在类的最后又添加了一个变量,名为values(),并有一个方法把上面的数组复制过来
public static org.yclframework.auth.test.dao.ibatis.Sex[] values();//声名values数组 invokestatic java.lang.System.arraycopy(java.lang.Object, int, java.lang.Object, int, int) : void [64] public static org.yclframework.auth.test.dao.ibatis.Sex valueOf(java.lang.String arg0);
这些方法是后来添加的,因为这个类用了很多的static final 不可改变的固定地址,JVM调用的时候用比较快。让我们反编译这个类来看看固定实现.
// Decompiled by Jad v1.5.8e2. Copyright 2001 Pavel Kouznetsov. // Jad home page: http://kpdus.tripod.com/jad.html // Decompiler options: packimports(3) fieldsfirst ansi space // Source File Name: Sex.java package org.yclframework.auth.test.dao.ibatis; import java.io.PrintStream; public final class Sex extends Enum { public static final Sex MAN; public static final Sex WOMAN; private final String sex; private static final Sex ENUM$VALUES[]; private Sex(String s, int i, String sex) { super(s, i); this.sex = sex; } public String getSex() { return sex; } public static void print(String sex) { if (sex.equals("MAN")) System.out.println(MAN.getSex()); else if (sex.equals("WOMAN")) System.out.println(WOMAN.getSex()); } public static Sex[] values() { Sex asex[]; int i; Sex asex1[]; System.arraycopy(asex = ENUM$VALUES, 0, asex1 = new Sex[i = asex.length], 0, i); return asex1; } public static Sex valueOf(String s) { return (Sex)Enum.valueOf(org/yclframework/auth/test/dao/ibatis/Sex, s); } static { MAN = new Sex("MAN", 0, "男"); WOMAN = new Sex("WOMAN", 1, "女"); ENUM$VALUES = (new Sex[] { MAN, WOMAN }); } }
一看代码就清楚了,原来这个类继承了enum,并调用父菜单,而我们可以直接声名为enum类型,添加了源代码,实现的功能却很丰富,这就是JDK5的魅力。
如果你把这个类用javac进行编译,对不起通不过。
Enum类不支持显示继承.
发表评论
-
Java Application Cache
2016-09-27 19:25 884Application Cache is used very ... -
Java 字符串分词
2015-01-02 14:43 1751在Java的世界里有个类型 ... -
jdk 1.6 新特性,集成Groovy, 性能很差
2014-04-02 14:27 1279性能都是相对的,如果调用量不是很大的话,可以忽略,毕竟使用为主 ... -
Fake Code easy implements
2014-04-01 15:41 1028package org.miniframe.modules ... -
JDK regex 用法及用途
2014-03-31 15:48 1216查找 Boolean flag = pattern.mat ... -
生产者消费者(四)
2014-03-04 12:32 1150需求: 多个生产者不断的生产产品,多个消费者不断的消费产品,仓 ... -
生产者消费者(三)
2014-03-04 10:59 961需求: 多个生产者不断的生产产品,多个消费者不断的消费产品,仓 ... -
生产者消费者(二)
2014-03-03 15:40 696需求: 多个生产者不断的生产产品,多个消费者不断的消费产品,仓 ... -
生产者消费者模式(一)
2014-02-28 14:30 1031需求: 多个生产者不断的生产产品,多个消费者不断的消费产品,仓 ... -
查看Class文件使用的JDK版本
2013-10-30 14:17 1116由于JDK一般是向下兼容的,所以有时候本地的JDK版本比类库的 ... -
Java源代码转码
2012-12-20 17:22 1324现在中国的项目很多,编码无非是UTF-8,GBK,GB2312 ... -
Tomcat集成OSGI,并通过JNDI开放Web调用
2012-12-03 11:22 3136Tomcat集成OSGi,首先要选择OSGI服务器,我这里采用 ... -
JDK的Logging
2012-11-07 15:49 1688jdk自带有一个log日志,对于一般的使用,仅够了. 代码如下 ... -
java.util.*
2012-11-06 14:23 1378java.util 工具包,灰常的有用,有机会一定要研读源码。 ... -
java.util.concurrent.*
2012-11-02 10:38 17781. java.util.concurrent.ArrayBl ... -
java.util.rt.*
2012-10-31 13:51 11161. java.util.HashMap 散列表,主要是以离散 ... -
巧秒设计方法,不返回null
2016-09-27 19:32 732/** * {@inheritDoc} * ... -
java doc 代码文档
2012-07-13 13:58 1333对于代码规范不解释了,网上很多。 在编写代码的时候,有一点灰 ... -
接口与抽象类
2012-07-11 16:53 11241. 接口设计必谨慎,除非业务变更,否则打死不能动接口。[不变 ... -
JVM优化机制好诡异
2012-04-20 08:43 1469long i[] = new long[1000000]; ...
相关推荐
jdk1.5中文版.CHM
8. **平台兼容性**:IBM JDK 1.5是针对AIX操作系统设计的,这意味着它能够充分利用AIX的特性,如RMA(远程方法调用)和PowerPC架构的优势。 在"IBM_jdk1.5_Guide.pdf"这个文档中,很可能是IBM JDK 1.5的官方指南或...
《深入理解Java Unsafe类在JDK 1.5中的应用》 在Java编程语言中,`Unsafe`类是一个特殊的存在,它提供了对内存操作的直接访问权限,绕过了Java的一些安全机制。在JDK 1.5版本的`rt.jar`库中,`Unsafe`类扮演着一个...
《深入解析JDK1.5 rt.jar源码》 在Java开发中,rt.jar是Java运行时库的核心组件,包含了Java标准类库的所有实现。对于Java开发者而言,深入理解rt.jar的源码对于提升技术水平、优化代码性能以及解决疑难问题至关...
例如,JDK1.5引入了泛型和枚举等新特性,JDK1.6则增强了并发处理和内存管理,这些变化可能会对jxl.jar的运行产生微妙的影响。 在JDK1.5环境下,jxl.jar通常能够正常工作,因为它的设计兼容了Java 1.3及更高版本。...
JDK1.5新特性
### JDK 1.5 新特性详解 #### 泛型编程 **定义与作用:** 泛型编程是 Java 1.5 引入的一项重要特性,它允许开发者在编译时进行类型安全检查,从而避免了运行时可能出现的类型转换异常。通过在编译阶段检查类型安全...
jdk1.5中文帮助.chm 网上整理的 制作了一下,比较方便查找
以下是JDK1.5中的主要新特性及其详细解释: 1. **泛型(Generics)**:泛型是JDK1.5引入的最大变革之一。它允许在类、接口和方法中使用类型参数,提高了代码的类型安全性和重用性。泛型帮助程序员在编译时检查类型...
jdk8新特性.md
jdk1.5.exe jdk1.5 jdk1.5下载
Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm
此外,JDK 1.5还引入了新的编译器——Client Compiler和Server Compiler,根据不同的场景选择合适的编译策略,提升代码执行速度。 总结,JDK 1.5的64位Windows版本为Java开发者提供了在64位系统上开发和运行Java...
枚举是 JDK 1.5 中引入的另一种新特性,用于替代传统的常量类,提供了一种更安全、更强大的方式来定义固定数量的值。枚举类型可以包含方法、变量,甚至实现接口。 - **声明枚举**:使用 `enum` 关键字定义枚举,如 ...
首先,JDK1.5引入了类型安全的枚举(enum),这是对原始的常量类的一个巨大改进。枚举类型使得代码更加清晰,更易于理解和维护,同时避免了因常量值的错误使用而导致的潜在问题。 其次,泛型(Generics)是JDK1.5的...
在语言特性方面,JDK 1.5引入了泛型(Generics),这是一种类型安全的集合框架,可以防止在运行时出现类型转换异常。泛型允许开发者在编译时就指定集合元素的类型,增强了代码的可读性和安全性。此外,自动装箱/拆箱...
JDK1.5引入了一些重要的特性,如增强的for循环(foreach)、匿名内部类的改进、枚举类型以及泛型的初步支持。这些特性对Java编程产生了深远影响,提升了代码的可读性和安全性。 然而,由于JDK1.5已不再受官方支持,...
总的来说,JDK 1.5 for Linux不仅为开发者提供了强大的编程工具,还通过引入一系列新特性,推动了Java语言的发展,使之更加高效和易用。无论是初学者还是经验丰富的开发者,都应熟悉并掌握这一版本,因为它对于理解...
JDK 1.5 引入了一系列重要的并发编程新特性,极大地改善了多线程环境下的程序设计。这些特性使得开发者能够编写更加高效、安全的并发应用程序。以下是对这些新特性的详细解释: 1. `TimeUnit`: `TimeUnit` 是一个...