小編給大家分享一下java使用枚舉的原因,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司專注于中大型企業(yè)的成都做網(wǎng)站、網(wǎng)站制作和網(wǎng)站改版、網(wǎng)站營銷服務(wù),追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術(shù)與技術(shù)開發(fā)的融合,累計客戶數(shù)千家,服務(wù)滿意度達97%。幫助廣大客戶順利對接上互聯(lián)網(wǎng)浪潮,準確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運用,我們將一直專注品牌網(wǎng)站制作和互聯(lián)網(wǎng)程序開發(fā),在前進的路上,與客戶一起成長!java為什么要使用枚舉?
假設(shè)現(xiàn)在有兩種訂單類型:預訂訂單和非預訂訂單。
需求一: 方法submitOrder根據(jù)不同訂單類型進行不同的處理。
需求二: 給一個對象: OrderResult設(shè)置訂單類型。
下面分別用兩種枚舉方式來實現(xiàn)。
int枚舉
class IntEnumExample{ private static final PRE_ORDER = 1; private static final NOT_PRE_ORDER = 2; public void submitOrder(int orderType, OrderResult orderResult){ orderResult.setType(orderType); if(orderType == PRE_ORDER){ do something to process preOrder }else if(orderType == NOT_PRE_ORDER){ do something to process other order } } public static void main(String [] args){ IntEnumExample example = new IntEnumExample(); //passing wrong type to the method, however, no compile error and runtime exception here, the bug is hard to be discerned. example.submitOrder(3, orderResult); } }
從上面的例子可以看到,使用int枚舉有幾個缺點:
1.int枚舉不做類型檢查,可以給上面的submitOrder方法傳入任意int值
2.代碼可讀性低,如果沒有文檔或者源碼,不知道給submitOrder傳遞的值的意義。
不僅如此,就像我之前修改項目中sonar掃描代碼發(fā)現(xiàn)的問題那樣,很多人在使用int枚舉時,并沒有像上例中將int值定義成static final。如果忘記定義變量為final則int枚舉的值就可以被修改,如果忘記定義變量為static,就可能出現(xiàn)使用這個int值時,該int值還沒有被初始化好。
總之,會引起bug。
下面來看看使用enum如何做同樣的事兒。
class IntEnumExample{ private enum ORDER_TYPE { NOT_PRE_ORDER(1),PRE_ORDER(2); private final int value; private ORDER_TYPE(int value){ this.value = value; } } public void submitOrder(ORDER_TYPE orderType, OrderResult orderResult){ orderResult.setType(orderType); if(orderType == ORDER_TYPE.PRE_ORDER){ do something to process preOrder }else if(orderType == ORDER_TYPE.NOT_PRE_ORDER){ do something to process other order } } public static void main(String [] args){ IntEnumExample example = new IntEnumExample(); //compiler will complain error here, if argument is not the type in the enum. example.submitOrder(ORDER_TYPE.PRE_ORDER, orderResult); } }
通過上述代碼可以看到,enum很優(yōu)雅的解決了上一個例子中的問題。
1.編譯器將對enum進行類型檢查,類型不符合的編譯器會直接報錯。
2.相比與int枚舉型直接傳int數(shù)值的方式,enum傳遞enum類型對象的方式,代碼可讀性更高,傳遞的枚舉類型一目了然。
3.enum類型中的對象本身就是static final的。
重要提示:
還有一點值得一提的是,如果有時想給每一個枚舉類型賦予一個int值,要使用上例中enum定義的方式。
private enum ORDER_TYPE { NOT_PRE_ORDER(1),PRE_ORDER(2); private final int value; private ORDER_TYPE(int value){ this.value = value; } }
enum本質(zhì)也是一個類,所以方法ORDER_TYPE(int value)是這個枚舉類型的構(gòu)造函數(shù),故每個枚舉類型在初始化的時候需要給構(gòu)造函數(shù)傳遞響應的值,如: PRE_ORDER(2)。
這種情況下,想得到枚舉類型對應的int數(shù)值時可以通過ORDER_TYPE.PRE_ORDER.value獲取。
單獨提下enum的這種用法是因為,有些人可能會直接使用enum中的ordinal()方法直接實現(xiàn)enum類型與int類型的關(guān)聯(lián)。ordinal()方法返回的是enum類型在被定義時的序數(shù),如ORDER_TYPE.PRE_ORDER.value.ordinal()返回值為0。所以獲取枚舉類型對應的int數(shù)值貌似也可以通過ORDER_TYPE.PRE_ORDER.value.ordinal()+1實現(xiàn)。
不要使用ordinal()方法!不要使用ordinal()方法!不要使用ordinal()方法!重要的事情說三遍,為什么?
序數(shù)是很不可靠的東西,序數(shù)是可以改變的,假設(shè)有一天ORDER_TYPE的定義變了,需要增加幾種類型,或者不小心換了NOT_PRE_ORDER和PRE_ORDER定義時的順序,如:
private enum ORDER_TYPE { PRE_ORDER,NOT_PRE_ORDER; }
這時就會造成很嚴重的bug,而且不好發(fā)現(xiàn),編譯時,運行時都不會有報錯。
所以,不要依賴ordianl()方法。
以上是java使用枚舉的原因的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。