Java 枚舉類和自定義枚舉類和enum聲明及實現接口的操作

1.枚舉類

註:

JDK1.5之前需要自定義枚舉類

JDK 1.5 新增的 enum 關鍵字用於定義枚舉類

若枚舉隻有一個成員, 則可以作為一種單例模式的實現方式

1.枚舉類的屬性

1、枚舉類對象的屬性不應允許被改動, 所以應該使用 private final 修飾

2、枚舉類的使用 private final 修飾的屬性應該在構造器中為其賦值

3、若枚舉類顯式的定義瞭帶參數的構造器, 則在列出枚舉值時也必須對應的傳入參數

2.自定義枚舉類

如何自定義枚舉類的方法寫在註釋裡

//自定義枚舉類
class Season {
 //1.提供類的屬性,聲明為private final
 private final String seasonName;
 private final String seasonDesc;
 //2.聲明為final的屬性,在構造器中初始化
 private Season(String seasonName,String seasonDesc) {
 this.seasonName = seasonName;
 this.seasonDesc = seasonDesc;
 }
 //3.通過公共的方法來調用屬性
 public final String getSeasonName() {
 return seasonName;
 }
 public final String getSeasonDesc() {
 return seasonDesc;
 }
 //4.創建枚舉類的對象:將類的對象聲明為public static final
 public static final Season SPRING = new Season("春天", "春暖花開");
 public static final Season SUMMER = new Season("夏天", "夏日炎炎");
 public static final Season FALL = new Season("秋天", "碩果累累");
 public static final Season WINTER = new Season("冬天", "白雪皚皚");
  
 @Override
 public String toString() {
 return "Season [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
 }
 public void show() {
 System.out.println("這個一個季節");
 }
}

Test

public static void main(String[] args) {
 Season spring = Season.SPRING;
 System.out.println(spring);
 spring.show();
 System.out.println(spring.getSeasonName() +" "+spring.getSeasonDesc());
 }
}

3.Enum枚舉類

1、必須在枚舉類的第一行聲明枚舉類對象。

2、枚舉類和普通類的區別:

①使用 enum 定義的枚舉類默認繼承瞭 java.lang.Enum 類

②枚舉類的構造器隻能使用 private 訪問控制符

③枚舉類的所有實例必須在枚舉類中顯式列出(, 分隔 ; 結尾). 列出的實例系統會自動添加 public static final 修飾

3、JDK 1.5 中可以在 switch 表達式中使用Enum定義的枚舉類的對象作為表達式, case 子句可以直接使用枚舉值的名字, 無需添加枚舉類作為限定

4、Dome

interface info{
 void show();
}
//枚舉類
enum Season1 implements info{
 SPRING("春天", "春暖花開"){
 public void show() {
 System.out.println("春天在哪裡?");
 }
 },
 SUMMER("夏天", "夏日炎炎")
 {
 public void show() {
  System.out.println("生如夏花");
 }
 } ,
 AUTUTO("秋天", "碩果累累")
 {
 public void show() {
  System.out.println("秋天是用來分手的季節");
 }
 },
 WINTER("冬天", "白雪皚皚")
 {
 public void show() {
  System.out.println("冬天裡的一把火");
 }
 };
 
 //1.提供類的屬性,聲明為private final
 private final String seasonName;
 private final String seasonDesc;
 //2.聲明為final的屬性,在構造器中初始化
 private Season1(String seasonName,String seasonDesc) {
 this.seasonName = seasonName;
 this.seasonDesc = seasonDesc;
 }
 //3.通過公共的方法來調用屬性
 public final String getSeasonName() {
 return seasonName;
 }
 public final String getSeasonDesc() {
 return seasonDesc;
 }
 
 @Override
 public String toString() {
 return "Season [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
 }
// public void show() {
// System.out.println("這個一個季節");
// }
}

Test

常用方法寫在註釋裡面

public class TestEnum {
 public static void main(String[] args) {
 System.out.println("------------enum關鍵字");
 //1.values():返回枚舉類數組
 Season1 [] seasons = Season1.values();
 for(int i = 0; i < seasons.length;i++) {
  System.out.println(seasons[i]);
 }
 //2.valueOf(String name):要求傳入的形參name是枚舉對象的名字
 //否則:報java.lang.IllegalArgumentException異常
 String str = "SPRING";
 Season1 sea = Season1.valueOf(str);
 System.out.println(sea);
 //線程的運行狀態
 Thread.State[] states = Thread.State.values();
 for (int i = 0; i < states.length; i++) {
  System.out.println(states[i]);
 } 
 }
}

4.實現接口的枚舉類

1、實現接口的枚舉類和普通 Java 類一樣,枚舉類可以實現一個或多個接口

2、若需要每個枚舉值在調用實現的接口方法呈現出不同的行為方式, 則可以讓每個枚舉值分別來實現該方法

3、實現方法可以看上面的demo。

補充:java新特性(枚舉,註解,接口定義加強)

一.枚舉

1.枚舉表達

enum ClassName
{
}

2.枚舉的本質:

多例設計模式

3.枚舉產生

JKD1.5產生枚舉,它隻是一種類型的包裝:使用enum關鍵字定義的枚舉本質上相當於class定義的類,默認繼承java.lang.Enum父類

4.枚舉中常見的方法

取得枚舉名字:public final String name()

取得枚舉序號:public final int ordinal()

取得所有枚舉對象:values():返回值類型:Enum[]

5.enum和Enum

enum是一個關鍵字,使用enum定義的枚舉本質上就相當於一個類繼承瞭Enum這個抽象類。

6.枚舉中可以定義的結構

可以有屬性,構造方法

枚舉中包含其他類結構,枚舉對象的聲明必須放在枚舉類的首行

枚舉可以實現接口,實現接口後,枚舉對象變成接口對象

二.註解(Annotation):JDK1.5新增最常用兩大特性。

JDK1.5提供的三大註解:@Override,@Deprecated,@SuppressWarnings

1.準確覆寫(@Override):

如果該方法覆寫正確,不會有編譯錯誤。如果方法名,參數列表與父類中同名方法不同,則會報錯。

public class Person
{
   @Override // 如果該方法覆寫正確,不會有編譯錯誤。如果方法名,參數列表與父類中同名方法不同,則會報錯。
  public String toString()
  {
  }
}

2.過期處理(@Deprecated):

作用於類和方法上,表示不推薦用戶使用此類或方法,但是能正常使用。

@Deprecated
public Void fun() {}

3.壓制警告(@SuppressWarnings):

當調用瞭某些操作可能產生問題的時候會出現警告進行,又不想總提示警告,這個時候可以使用註解壓制警告。

三.接口定義加強

JDK8以前:全局變量+抽象方法

JDK8以後:

1.default定義的普通方法,通過對象調用

2.static定義的靜態方法,通過接口調用

interface Imessage
{
  public default void fun()   //追加普通方法,有方法體
  {
    System.out.println("Holle IMessage");
  }
  
  public static IMessage getInstance()  //可以由接口名稱直接調用
  {
    return new MessageImp();
  }
  public void print();
}
class MessageImp imlements Imessage
{
  @Override
  public void print()
  {
    System.out.println("Holle MessageImp ");
  }
}

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。

推薦閱讀: