網(wǎng)站建設遠程工作搜索引擎優(yōu)化方案
第八章:枚舉類與注解
8.1:枚舉類的使用
? 類的對象只有有限個,確定的。我們稱此類為枚舉類。當需要定義一組常量是,強烈建議使用枚舉類。如果枚舉類中只有一個對象,則可以作為單例模式的實現(xiàn)方式。
-
如何定義枚舉類
-
方式一:
JDK5.0
之前,自定義枚舉類。public class SeasonTest {public static void main(String[] args) {Season spring = Season.SPRING;System.out.println(spring); // Season{seasonName=春天,seasonDesc=春暖花開}} } //自定義枚舉類 class Season{//1.聲明Season對象的屬性:private final修飾private final String seasonName;private final String seasonDesc;//2.私有化類的構(gòu)造器,并給對象屬性賦值private Season(String seasonName,String seasonDesc){this.seasonName = seasonName;this.seasonDesc = seasonDesc;}//3.提供當前枚舉類的多個對象:public static final的public static final Season SPRING = new Season("春天","春暖花開");public static final Season SUMMER = new Season("夏天","夏日炎炎");public static final Season AUTUMN = new Season("秋天","秋高氣爽");public static final Season WINTER = new Season("冬天","冰天雪地");//4.其他訴求1:獲取枚舉類對象的屬性public String getSeasonName() {return seasonName;}public String getSeasonDesc() {return seasonDesc;}//4.其他訴求1:提供toString()@Overridepublic String toString() {return "Season{" +"seasonName='" + seasonName + '\'' +", seasonDesc='" + seasonDesc + '\'' +'}';} }
-
方式二:
JDK5.0
,可以使用enum
關(guān)鍵字定義枚舉類。public class SeasonTest1 {public static void main(String[] args) {Season1 summer = Season1.SUMMER;System.out.println(summer); // Season{seasonName=春天,seasonDesc=春暖花開}System.out.println(Season1.class.getSuperclass()); // Enum} } //使用enum關(guān)鍵字枚舉類 enum Season1 implements Info{//1.提供當前枚舉類的對象,多個對象之間用","隔開,末尾對象";"結(jié)束SPRING("春天","春暖花開"),SUMMER("夏天","夏日炎炎"),AUTUMN("秋天","秋高氣爽"),WINTER("冬天","冰天雪地");//2.聲明Season對象的屬性:private final修飾private final String seasonName;private final String seasonDesc;//2.私有化類的構(gòu)造器,并給對象屬性賦值private Season1(String seasonName,String seasonDesc){this.seasonName = seasonName;this.seasonDesc = seasonDesc;}//4.其他訴求1:獲取枚舉類對象的屬性public String getSeasonName() {return seasonName;}public String getSeasonDesc() {return seasonDesc;}//4.其他訴求1:提供toString()@Overridepublic String toString() {return "Season1{" +"seasonName='" + seasonName + '\'' +", seasonDesc='" + seasonDesc + '\'' +'}';} }
-
-
Enum
類中常用的方法values()
:返回枚舉類型的對象數(shù)組。該方法可以很方便地遍歷所有的枚舉值。valueOf(String str)
:返回枚舉類中對象名str
的對象,如果沒有就拋異常。toString()
:返回當前枚舉類對象常量名稱。
Season1 summer = Season1.SUMMER; //toString():返回枚舉類對象的名稱 System.out.println(summer.toString()); //values():返回所有的枚舉類對象構(gòu)成的數(shù)組 Season1[] values = Season1.values(); for(int i = 0;i < values.length;i++){System.out.println(values[i]); } //valueOf(String objName):返回枚舉類中對象名是objName的對象。 Season1 winter = Season1.valueOf("WINTER"); System.out.println(winter);
-
使用
enum
關(guān)鍵字定義的枚舉類實現(xiàn)接口的情況- 情況一:實現(xiàn)接口,在
enum
類中實現(xiàn)抽象方法。 - 情況二:讓枚舉類的對象分別實現(xiàn)接口中的抽象方法。
- 情況一:實現(xiàn)接口,在
8.2:注解
-
理解注解(
Annotation
)- 從
JDK 5.0
開始,Java
增加了對元數(shù)據(jù)MetaData
的支持,也就是Annotation
(注解)。 Annotation
其實就是代碼里的特殊標記,這些標記可以在編譯,類加載,運行時被讀取,并執(zhí)行相應的處理。通過使用Annotation
,程序員可以在不改變原有邏輯的情況下,在源文件中嵌入一些補充信息。
- 從
-
注解實例
-
@Override
:限定重寫父類方法,該注解只能用于方法。class Person{private String name;private int age;public Person() {}public Person(String name, int age) {this.name = name;this.age = age;}public void walk() {System.out.println("人走路");} }class Student extends Person{@Overridepublic void walk() {System.out.println("學生走路");} }
-
@Deprecated
:用于表示所修飾的元素(類,方法等)已過時。通常是因為所修飾的結(jié)構(gòu)危險或存在更好的選擇。@Deprecated public Date(int year, int month, int date) {this(year, month, date, 0, 0, 0); }
-
@SuppressWarnings
:抑制編譯器警告。@SuppressWarnings("unused") int num = 10; @SuppressWarnings({"unused", "rawtypes"}) ArrayList list = new ArrayList();
-
-
自定義
Annotation
- 注解類型聲明為:
@interface
。 - 自定義注解自動繼承了
java.lang.annotation.Annotation
接口。 - 注解的成員變量在
Annotation
定義中以無參數(shù)方法的形式來聲明。其方法名和返回值定義了該成員的名字和類型。我們稱為配置參數(shù)。類型只能是八種基本數(shù)據(jù)類型、String
、Class
、enum
、Annotation
類型。 - 內(nèi)部定義成員,通常使用
value
表示。 - 可以指定成員的默認值,使用
default
定義。 - 如果定義的注解含有配置參數(shù),那么使用時必須指定參數(shù)值,除非它有默認值。格式是
參數(shù)名 = 參數(shù)值
,如果只有一個參數(shù)成員,且名稱為value
,可以省略value=
。 - 如果自定義注解沒有成員,表名是一個標識作用。
public @interface MyAnnotation {String value() default "hello"; }
注意:自定義注解必須配上注解的信息處理流程才有意義。
- 注解類型聲明為:
-
JDK
中的元注解-
JDK
的元Annoation
用于修飾其他Annotation
定義。 -
JDK 5.0
提供了4個標準的meta-annontation
類型,分別是:-
Retention
? 只能用于修飾一個
Annotation
定義,用于指定該Annotation
的生命周期,@Rentention
包含一個RetentionPolicy
類型的成員變量,使用@Rentention
時必須為該value
成員變量指定值:RetentionPolicy.COURCE
:在源文件中有效(即源文件保留),編譯器直接丟棄這種策略的注釋。RetentionPolicy.CLASS
:在class
文件中有效(即class
保留),當運行Java
程序時,不會保留注解。這是默認值。RetentionPolicy.RUNTIME
:在運行時有效(即運行時保留),當運行Java
程序時,JVM
會保留注釋。程序可以通過反射獲取該注釋。
-
Target
? 用于修飾
Annotation
定義,用于指定被修飾的Annotation
能用于修飾哪些程序元素。@Target
也包含一個名為value
的成員變量。
-
Documented
? 用于指定被該元
Annotation
修飾的Annotation
類將被javadoc
工具提取成文檔。默認情況下,javadoc
是不包括注解的。? 定義為
Documented
的注解必須設置Retention
值為RUNTIME
。 -
Inherited
? 被它修飾的
Annotation
將具有繼承性。如果某個類使用了被@Inherited
修飾的Annotation
,則其子類將自動具有該注解。
-
-
-
JDK 8
中注解的新特性-
可重復注解
- 在
MyAnnotation
上聲明@Repeatable
,成員值為MyAnnotations.class
MyAnnotation
的Target
和Retention
等元注解與MyAnnotations
相同
@Inherited @Repeatable(MyAnnotations.class) @Retention(RetentionPolicy.RUNTIME) @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE,TYPE_PARAMETER,TYPE_USE}) public @interface MyAnnotation {String value() default "hello"; }
@Inherited @Retention(RetentionPolicy.RUNTIME) @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE,TYPE_PARAMETER,TYPE_USE}) public @interface MyAnnotations {MyAnnotation[] value(); }
@MyAnnotation(value = "hi") @MyAnnotation(value = "abc") class Person{ }
- 在
-
類型注解
ElementType.TYPE_RARAMETER
:表示該注解能寫在類型變量的聲明語句中。ElementType.TYPE_USE
:表示該注解能寫在使用類型的任何語句中。
-