Java 枚舉類和自定義枚舉類和enum聲明及實現(xiàn)接口的操作
1.枚舉類
注:
JDK1.5之前需要自定義枚舉類
JDK 1.5 新增的 enum 關鍵字用于定義枚舉類
若枚舉只有一個成員, 則可以作為一種單例模式的實現(xiàn)方式
1.枚舉類的屬性
1、枚舉類對象的屬性不應允許被改動, 所以應該使用 private final 修飾
2、枚舉類的使用 private final 修飾的屬性應該在構造器中為其賦值
3、若枚舉類顯式的定義了帶參數(shù)的構造器, 則在列出枚舉值時也必須對應的傳入?yún)?shù)
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.創(chuàng)建枚舉類的對象:將類的對象聲明為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("這個一個季節(jié)");
}
}
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、枚舉類和普通類的區(qū)別:
①使用 enum 定義的枚舉類默認繼承了 java.lang.Enum 類
②枚舉類的構造器只能使用 private 訪問控制符
③枚舉類的所有實例必須在枚舉類中顯式列出(, 分隔 ; 結尾). 列出的實例系統(tǒng)會自動添加 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("秋天是用來分手的季節(jié)");
}
},
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("這個一個季節(jié)");
// }
}
Test
常用方法寫在注釋里面
public class TestEnum {
public static void main(String[] args) {
System.out.println("------------enum關鍵字");
//1.values():返回枚舉類數(shù)組
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);
//線程的運行狀態(tài)
Thread.State[] states = Thread.State.values();
for (int i = 0; i < states.length; i++) {
System.out.println(states[i]);
}
}
}
4.實現(xiàn)接口的枚舉類
1、實現(xiàn)接口的枚舉類和普通 Java 類一樣,枚舉類可以實現(xiàn)一個或多個接口
2、若需要每個枚舉值在調用實現(xiàn)的接口方法呈現(xiàn)出不同的行為方式, 則可以讓每個枚舉值分別來實現(xiàn)該方法
3、實現(xiàn)方法可以看上面的demo。
補充:java新特性(枚舉,注解,接口定義加強)
一.枚舉
1.枚舉表達
enum ClassName
{
}
2.枚舉的本質:
多例設計模式
3.枚舉產(chǎn)生
JKD1.5產(chǎn)生枚舉,它只是一種類型的包裝:使用enum關鍵字定義的枚舉本質上相當于class定義的類,默認繼承java.lang.Enum父類
4.枚舉中常見的方法
取得枚舉名字:public final String name()
取得枚舉序號:public final int ordinal()
取得所有枚舉對象:values():返回值類型:Enum[]
5.enum和Enum
enum是一個關鍵字,使用enum定義的枚舉本質上就相當于一個類繼承了Enum這個抽象類。
6.枚舉中可以定義的結構
可以有屬性,構造方法
枚舉中包含其他類結構,枚舉對象的聲明必須放在枚舉類的首行
枚舉可以實現(xiàn)接口,實現(xiàn)接口后,枚舉對象變成接口對象
二.注解(Annotation):JDK1.5新增最常用兩大特性。
JDK1.5提供的三大注解:@Override,@Deprecated,@SuppressWarnings
1.準確覆寫(@Override):
如果該方法覆寫正確,不會有編譯錯誤。如果方法名,參數(shù)列表與父類中同名方法不同,則會報錯。
public class Person
{
@Override // 如果該方法覆寫正確,不會有編譯錯誤。如果方法名,參數(shù)列表與父類中同名方法不同,則會報錯。
public String toString()
{
}
}
2.過期處理(@Deprecated):
作用于類和方法上,表示不推薦用戶使用此類或方法,但是能正常使用。
@Deprecated
public Void fun() {}
3.壓制警告(@SuppressWarnings):
當調用了某些操作可能產(chǎn)生問題的時候會出現(xiàn)警告進行,又不想總提示警告,這個時候可以使用注解壓制警告。
三.接口定義加強
JDK8以前:全局變量+抽象方法
JDK8以后:
1.default定義的普通方法,通過對象調用
2.static定義的靜態(tài)方法,通過接口調用
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 ");
}
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
Java編程Iterator迭代器設計原理及實現(xiàn)代碼示例
這篇文章主要介紹了Java編程Iterator迭代器設計原理及實現(xiàn)代碼示例,具有一定參考價值,需要的朋友可以了解下。2017-10-10
Netty分布式ByteBuf使用page級別的內存分配解析
這篇文章主要介紹了Netty分布式ByteBuf使用page級別的內存分配解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
spring?boot?導出數(shù)據(jù)到excel的操作步驟(demo)
這篇文章主要介紹了spring?boot?導出數(shù)據(jù)到excel的實現(xiàn)步驟,文中通過打開一個平時練習使用的springboot的demo給大家詳細介紹,需要的朋友可以參考下2022-03-03
SpringBoot與Redis的令牌主動失效機制實現(xiàn)
本文詳細介紹了基于SpringBoot和Redis實現(xiàn)令牌主動失效機制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-12-12

