Java實(shí)現(xiàn)枚舉狀態(tài)轉(zhuǎn)換的方法詳解
場(chǎng)景描述
假設(shè)我們有一個(gè)電商系統(tǒng),包含兩個(gè)核心狀態(tài)枚舉:
- 訂單狀態(tài)(OrderStatusEnum) - 描述訂單在電商系統(tǒng)中的生命周期
- 物流狀態(tài)(ShippingStatusEnum) - 描述訂單在物流系統(tǒng)中的流轉(zhuǎn)狀態(tài)
這兩個(gè)狀態(tài)密切相關(guān)但又不完全相同,我們需要在它們之間建立轉(zhuǎn)換關(guān)系。
枚舉定義
1. 訂單狀態(tài)枚舉
/** * 訂單狀態(tài)枚舉 */ public enum OrderStatusEnum { UNPAID(0, "待支付"), PAID(1, "已支付"), PACKAGED(2, "已打包"), SHIPPED(3, "已發(fā)貨"), DELIVERED(4, "已送達(dá)"), COMPLETED(5, "已完成"), CANCELLED(10, "已取消"), REFUNDING(11, "退款中"), REFUNDED(12, "已退款"); private final int code; private final String description; OrderStatusEnum(int code, String description) { this.code = code; this.description = description; } // 根據(jù)code獲取枚舉實(shí)例 public static OrderStatusEnum fromCode(int code) { for (OrderStatusEnum status : values()) { if (status.code == code) { return status; } } throw new IllegalArgumentException("無(wú)效的訂單狀態(tài)碼: " + code); } // 轉(zhuǎn)換為物流狀態(tài) public ShippingStatusEnum toShippingStatus() { switch (this) { case UNPAID: case PAID: case CANCELLED: case REFUNDING: case REFUNDED: return null; // 這些訂單狀態(tài)沒(méi)有對(duì)應(yīng)的物流狀態(tài) case PACKAGED: return ShippingStatusEnum.PREPARING; case SHIPPED: return ShippingStatusEnum.IN_TRANSIT; case DELIVERED: return ShippingStatusEnum.DELIVERED; case COMPLETED: return ShippingStatusEnum.COMPLETED; default: throw new IllegalStateException("未知的訂單狀態(tài): " + this); } } // getters public int getCode() { return code; } public String getDescription() { return description; } }
2. 物流狀態(tài)枚舉
/** * 物流狀態(tài)枚舉 */ public enum ShippingStatusEnum { PREPARING(1, "準(zhǔn)備中"), IN_TRANSIT(2, "運(yùn)輸中"), DELIVERED(3, "已送達(dá)"), COMPLETED(4, "已完成"), RETURNING(10, "退貨中"), RETURNED(11, "已退貨"); private final int code; private final String description; ShippingStatusEnum(int code, String description) { this.code = code; this.description = description; } // 根據(jù)code獲取枚舉實(shí)例 public static ShippingStatusEnum fromCode(int code) { for (ShippingStatusEnum status : values()) { if (status.code == code) { return status; } } throw new IllegalArgumentException("無(wú)效的物流狀態(tài)碼: " + code); } // 轉(zhuǎn)換為訂單狀態(tài) public OrderStatusEnum toOrderStatus() { switch (this) { case PREPARING: return OrderStatusEnum.PACKAGED; case IN_TRANSIT: return OrderStatusEnum.SHIPPED; case DELIVERED: return OrderStatusEnum.DELIVERED; case COMPLETED: return OrderStatusEnum.COMPLETED; case RETURNING: return OrderStatusEnum.REFUNDING; case RETURNED: return OrderStatusEnum.REFUNDED; default: throw new IllegalStateException("未知的物流狀態(tài): " + this); } } // getters public int getCode() { return code; } public String getDescription() { return description; } }
關(guān)鍵設(shè)計(jì)點(diǎn)解析
狀態(tài)映射關(guān)系:
- 不是所有訂單狀態(tài)都有對(duì)應(yīng)的物流狀態(tài)(如待支付、已取消等)
- 物流狀態(tài)可能觸發(fā)訂單狀態(tài)的變更(如退貨中對(duì)應(yīng)退款中)
轉(zhuǎn)換方法設(shè)計(jì):
- 每個(gè)枚舉類(lèi)內(nèi)部實(shí)現(xiàn)轉(zhuǎn)換方法,知道如何轉(zhuǎn)換為另一種狀態(tài)
- 方法命名直觀:
toShippingStatus()
和toOrderStatus()
null值處理:
- 當(dāng)沒(méi)有對(duì)應(yīng)狀態(tài)時(shí)返回null,調(diào)用方需要處理這種情況
異常處理:
- 對(duì)非法狀態(tài)碼拋出明確的異常信息
使用示例
// 訂單狀態(tài)轉(zhuǎn)物流狀態(tài) OrderStatusEnum orderStatus = OrderStatusEnum.SHIPPED; ShippingStatusEnum shippingStatus = orderStatus.toShippingStatus(); System.out.println("訂單狀態(tài): " + orderStatus.getDescription() + " → 物流狀態(tài): " + (shippingStatus != null ? shippingStatus.getDescription() : "無(wú)")); // 物流狀態(tài)轉(zhuǎn)訂單狀態(tài) ShippingStatusEnum shippingStatus = ShippingStatusEnum.RETURNING; OrderStatusEnum orderStatus = shippingStatus.toOrderStatus(); System.out.println("物流狀態(tài): " + shippingStatus.getDescription() + " → 訂單狀態(tài): " + orderStatus.getDescription());
最佳實(shí)踐建議
保持轉(zhuǎn)換邏輯簡(jiǎn)單:如果轉(zhuǎn)換邏輯變得復(fù)雜,考慮引入狀態(tài)模式
文檔化映射關(guān)系:在枚舉類(lèi)或項(xiàng)目文檔中明確記錄狀態(tài)映射關(guān)系
單元測(cè)試:為狀態(tài)轉(zhuǎn)換編寫(xiě)單元測(cè)試,確保轉(zhuǎn)換邏輯正確
考慮性能:對(duì)于高頻調(diào)用的場(chǎng)景,可以緩存轉(zhuǎn)換結(jié)果
擴(kuò)展性:設(shè)計(jì)時(shí)考慮未來(lái)可能新增的狀態(tài)
總結(jié)
通過(guò)在枚舉內(nèi)部實(shí)現(xiàn)狀態(tài)轉(zhuǎn)換方法,我們實(shí)現(xiàn)了:
- 高內(nèi)聚的設(shè)計(jì):轉(zhuǎn)換邏輯與狀態(tài)定義在一起
- 易于維護(hù):狀態(tài)變更時(shí)只需修改一處
- 類(lèi)型安全:編譯時(shí)檢查狀態(tài)轉(zhuǎn)換
- 代碼清晰:直觀的轉(zhuǎn)換方法調(diào)用
這種模式不僅適用于訂單和物流狀態(tài),還可以應(yīng)用于各種需要狀態(tài)轉(zhuǎn)換的場(chǎng)景,如工作流狀態(tài)、支付狀態(tài)等。
到此這篇關(guān)于Java實(shí)現(xiàn)枚舉狀態(tài)轉(zhuǎn)換的方法詳解的文章就介紹到這了,更多相關(guān)Java枚舉狀態(tài)轉(zhuǎn)換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java使用JDBC連接數(shù)據(jù)庫(kù)的詳細(xì)步驟
本文詳細(xì)講解了Java使用JDBC連接數(shù)據(jù)庫(kù)的詳細(xì)步驟,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01線程池之exectue與submit的區(qū)別及說(shuō)明
這篇文章主要介紹了線程池之exectue與submit的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08一文搞懂Java設(shè)計(jì)模式之責(zé)任鏈模式
這篇文章主要給大家介紹了關(guān)于Java設(shè)計(jì)模式之責(zé)任鏈模式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12Java單機(jī)環(huán)境實(shí)現(xiàn)定時(shí)任務(wù)技術(shù)
這篇文章主要介紹了Java單機(jī)環(huán)境實(shí)現(xiàn)定時(shí)任務(wù)技術(shù),文章內(nèi)容介紹詳細(xì),具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-04-04IDEA中maven依賴(lài)報(bào)紅的問(wèn)題解決辦法
這篇文章主要給大家介紹了關(guān)于IDEA中maven依賴(lài)報(bào)紅的問(wèn)題解決辦法,在使用IDEA過(guò)程中,經(jīng)常會(huì)出現(xiàn)maven依賴(lài)報(bào)紅的問(wèn)題,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07Java從零編寫(xiě)吃貨聯(lián)盟訂餐系統(tǒng)全程講解
這篇文章主要介紹了Java訂餐系統(tǒng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-12-12