From 577b73874b0f4f5e2c9cc814291be0536a671caa Mon Sep 17 00:00:00 2001 From: ZhouXY108 Date: Mon, 9 Jun 2025 11:10:03 +0800 Subject: [PATCH] =?UTF-8?q?refactor:=20=E9=87=8D=E6=9E=84=20MultiTypesExce?= =?UTF-8?q?ption.ExceptionType=20=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 将 `ExceptionType` 中的工厂方法抽取到 `ExceptionFactory` 中 - 更新相关文档注释 --- .../commons/exception/ExceptionFactory.java | 61 +++++++++++++++++++ .../exception/MultiTypesException.java | 46 +++----------- .../commons/exception/package-info.java | 3 +- 3 files changed, 70 insertions(+), 40 deletions(-) create mode 100644 plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java new file mode 100644 index 0000000..0f2e8bf --- /dev/null +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java @@ -0,0 +1,61 @@ +/* + * Copyright 2025 the original author or authors. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package xyz.zhouxy.plusone.commons.exception; + +import javax.annotation.Nonnull; + +/** + * 异常工厂 + * + * @author ZhouXY + */ +public interface ExceptionFactory { + /** + * 创建异常 + * + * @return 异常对象 + */ + @Nonnull + X create(); + + /** + * 使用指定 {@code message} 创建异常 + * + * @param message 异常信息 + * @return 异常对象 + */ + @Nonnull + X create(String message); + + /** + * 使用指定 {@code cause} 创建异常 + * + * @param cause 包装的异常 + * @return 异常对象 + */ + @Nonnull + X create(Throwable cause); + + /** + * 使用指定 {@code message} 和 {@code cause} 创建异常 + * + * @param message 异常信息 + * @param cause 包装的异常 + * @return 异常对象 + */ + @Nonnull + X create(String message, Throwable cause); +} diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java index d0ade7b..ab30607 100644 --- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java @@ -29,7 +29,8 @@ import xyz.zhouxy.plusone.commons.base.IWithCode; * 异常实现 {@link MultiTypesException} 的 {@link #getType} 方法,返回对应的场景类型。 * *

- * 表示场景类型的枚举实现 {@link ExceptionType},其中的工厂方法用于创建对应类型的异常。 + * 表示场景类型的枚举实现 {@link ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException
@@ -120,7 +121,9 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  * @author ZhouXY
  * @since 1.0.0
  */
-public interface MultiTypesException> {
+public interface MultiTypesException<
+        X extends Exception,
+        T extends MultiTypesException.ExceptionType> {
 
     /**
      * 异常类型
@@ -142,48 +145,13 @@ public interface MultiTypesException extends IWithCode {
+    public static interface ExceptionType
+            extends IWithCode, ExceptionFactory {
 
         /**
          * 默认异常信息
          */
         String getDefaultMessage();
 
-        /**
-         * 创建异常
-         *
-         * @return 异常对象
-         */
-        @Nonnull
-        E create();
-
-        /**
-         * 使用指定 {@code message} 创建异常
-         *
-         * @param message 异常信息
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(String message);
-
-        /**
-         * 使用指定 {@code cause} 创建异常
-         *
-         * @param cause 包装的异常
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(Throwable cause);
-
-        /**
-         * 使用指定 {@code message} 和 {@code cause} 创建异常
-         *
-         * @param message 异常信息
-         * @param cause   包装的异常
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(String message, Throwable cause);
-
     }
 }
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
index 851002c..4e56f50 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
@@ -25,7 +25,8 @@
  * 异常实现 {@link MultiTypesException} 的 {@link MultiTypesException#getType} 方法,返回对应的场景类型。
  *
  * 

- * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType},其中的工厂方法用于创建对应类型的异常。 + * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException