docs: 修改 javadoc 中的格式错误

This commit is contained in:
zhouxy108 2025-06-08 13:08:45 +08:00
parent 336d99d4ba
commit 89acbecc5a
42 changed files with 32 additions and 80 deletions

View File

@ -24,17 +24,15 @@
* 标识<b>静态工厂方法</b> * 标识<b>静态工厂方法</b>
* Effective Java Item1 建议考虑用静态工厂方法替换构造器 * Effective Java Item1 建议考虑用静态工厂方法替换构造器
* 因而考虑有一个注解可以标记一下静态工厂方法以和其它方法进行区分 * 因而考虑有一个注解可以标记一下静态工厂方法以和其它方法进行区分
* </p>
* *
* <h3> * <h3>
* 2. {@link ReaderMethod} {@link WriterMethod} * 2. {@link ReaderMethod} {@link WriterMethod}
* </h3> * </h3>
* <p> * <p>
* 分别标识<b>读方法</b> getter<b>写方法</b> setter * 分别标识<b>读方法</b> getter<b>写方法</b> setter
* </p> *
* <p> * <p>
* 最早是写了一个集合类为了方便判断使用读写锁时哪些情况下使用读锁哪些情况下使用写锁 * 最早是写了一个集合类为了方便判断使用读写锁时哪些情况下使用读锁哪些情况下使用写锁
* </p>
* *
* <h3> * <h3>
* 3. {@link UnsupportedOperation} * 3. {@link UnsupportedOperation}
@ -42,22 +40,19 @@
* <p> * <p>
* 标识该方法不被支持或没有实现将抛出 {@link UnsupportedOperationException} * 标识该方法不被支持或没有实现将抛出 {@link UnsupportedOperationException}
* 为了方便在使用时不需要点进源码就能知道该方法没有实现 * 为了方便在使用时不需要点进源码就能知道该方法没有实现
* </p>
* *
* <h3> * <h3>
* 4. {@link Virtual} * 4. {@link Virtual}
* </h3> * </h3>
* <p> * <p>
* Java final 的实例方法对应 C++/C# 中的虚方法允许被子类覆写 * Java final 的实例方法对应 C++/C&num; 中的虚方法允许被子类覆写
* {@link Virtual} 注解旨在设计父类时强调该方法父类虽然有默认实现但子类可以根据自己的需要覆写 * {@link Virtual} 注解旨在设计父类时强调该方法父类虽然有默认实现但子类可以根据自己的需要覆写
* </p>
* *
* <h3> * <h3>
* 5. {@link ValueObject} * 5. {@link ValueObject}
* </h3> * </h3>
* <p> * <p>
* 标记一个类表示其作为值对象区别于 Entity * 标记一个类表示其作为值对象区别于 Entity
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */

View File

@ -27,7 +27,7 @@ import javax.annotation.Nullable;
/** /**
* {@link Ref} 包装了一个值表示对该值的应用 * {@link Ref} 包装了一个值表示对该值的应用
* *
* <p>灵感来自于 C# {@value ref} 参数修饰符C# 允许通过以下方式将值返回给调用端</p> * <p>灵感来自于 C&num; {@code ref} 参数修饰符C&num; 允许通过以下方式将值返回给调用端</p>
* <pre> * <pre>
* void Method(ref int refArgument) * void Method(ref int refArgument)
* { * {
@ -51,7 +51,7 @@ import javax.annotation.Nullable;
* <p> * <p>
* 当一个方法需要产生多个结果时无法有多个返回值可以使用 {@link Ref} 作为参数传入方法内部修改 {@link Ref} 的值 * 当一个方法需要产生多个结果时无法有多个返回值可以使用 {@link Ref} 作为参数传入方法内部修改 {@link Ref} 的值
* 调用方在调用方法之后使用 {@code getValue()} 获取结果 * 调用方在调用方法之后使用 {@code getValue()} 获取结果
* </p> *
* <pre> * <pre>
* String method(final Ref&lt;Integer&gt; intRefArgument, final Ref&lt;String&gt; strRefArgument) { * String method(final Ref&lt;Integer&gt; intRefArgument, final Ref&lt;String&gt; strRefArgument) {
* intRefArgument.transformValue(i -&gt; i + 44); * intRefArgument.transformValue(i -&gt; i + 44);

View File

@ -20,8 +20,8 @@
* <h3>1. Ref</h3> * <h3>1. Ref</h3>
* <p> * <p>
* {@link Ref} 包装了一个值表示对该值的应用 * {@link Ref} 包装了一个值表示对该值的应用
* </p> *
* <p>灵感来自于 C# {@value ref} 参数修饰符C# 允许通过以下方式将值返回给调用端</p> * <p>灵感来自于 C&num; {@code ref} 参数修饰符C&num; 允许通过以下方式将值返回给调用端</p>
* <pre> * <pre>
* void Method(ref int refArgument) * void Method(ref int refArgument)
* { * {
@ -45,7 +45,7 @@
* <p> * <p>
* 当一个方法需要产生多个结果时无法有多个返回值可以使用 {@link Ref} 作为参数传入方法内部修改 {@link Ref} 的值 * 当一个方法需要产生多个结果时无法有多个返回值可以使用 {@link Ref} 作为参数传入方法内部修改 {@link Ref} 的值
* 调用方在调用方法之后使用 {@code getValue()} 获取结果 * 调用方在调用方法之后使用 {@code getValue()} 获取结果
* </p> *
* <pre> * <pre>
* String method(Ref&lt;Integer&gt; intRefArgument, Ref&lt;String&gt; strRefArgument) { * String method(Ref&lt;Integer&gt; intRefArgument, Ref&lt;String&gt; strRefArgument) {
* intRefArgument.transformValue(i -&gt; i + 44); * intRefArgument.transformValue(i -&gt; i + 44);
@ -65,7 +65,6 @@
* <p> * <p>
* 类似于枚举这样的类型通常需要设置固定的码值表示对应的含义 * 类似于枚举这样的类型通常需要设置固定的码值表示对应的含义
* 可实现 {@link IWithCode}{@link IWithIntCode}{@link IWithLongCode}便于在需要的地方对这些接口的实现进行处理 * 可实现 {@link IWithCode}{@link IWithIntCode}{@link IWithLongCode}便于在需要的地方对这些接口的实现进行处理
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */

View File

@ -15,7 +15,7 @@
*/ */
/** /**
* <h2>集合<h2> * <h2>集合</h2>
* *
* <h3> * <h3>
* 1. {@link CollectionTools} * 1. {@link CollectionTools}

View File

@ -31,7 +31,7 @@ public final class PatternConsts {
* yyyyMMdd * yyyyMMdd
* *
* @see RegexConsts#BASIC_ISO_DATE * @see RegexConsts#BASIC_ISO_DATE
* </p> *
*/ */
public static final Pattern BASIC_ISO_DATE = Pattern.compile(RegexConsts.BASIC_ISO_DATE); public static final Pattern BASIC_ISO_DATE = Pattern.compile(RegexConsts.BASIC_ISO_DATE);

View File

@ -15,7 +15,7 @@
*/ */
/** /**
* <h2>常量<h2> * <h2>常量</h2>
* *
* <h3> * <h3>
* 1. 正则常量 * 1. 正则常量

View File

@ -24,13 +24,12 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
* *
* <p> * <p>
* 异常在不同场景下被抛出可以用不同的枚举值表示不同的场景类型 * 异常在不同场景下被抛出可以用不同的枚举值表示不同的场景类型
* </p> *
* <p> * <p>
* 异常实现 {@link MultiTypesException} {@link #getType} 方法返回对应的场景类型 * 异常实现 {@link MultiTypesException} {@link #getType} 方法返回对应的场景类型
* </p> *
* <p> * <p>
* 表示场景类型的枚举实现 {@link ExceptionType}其中的工厂方法用于创建对应类型的异常 * 表示场景类型的枚举实现 {@link ExceptionType}其中的工厂方法用于创建对应类型的异常
* </p>
* *
* <pre> * <pre>
* public final class LoginException * public final class LoginException
@ -61,7 +60,7 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
* *
* // ... * // ...
* *
* public enum Type implements ExceptionType<LoginException> { * public enum Type implements ExceptionType&lt;LoginException&gt; {
* DEFAULT("00", "当前会话未登录"), * DEFAULT("00", "当前会话未登录"),
* NOT_TOKEN("10", "未提供token"), * NOT_TOKEN("10", "未提供token"),
* INVALID_TOKEN("20", "token无效"), * INVALID_TOKEN("20", "token无效"),
@ -117,7 +116,6 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
* <pre> * <pre>
* throw LoginException.Type.TOKEN_TIMEOUT.create(); * throw LoginException.Type.TOKEN_TIMEOUT.create();
* </pre> * </pre>
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -33,7 +33,6 @@ import xyz.zhouxy.plusone.commons.exception.MultiTypesException.ExceptionType;
* <pre> * <pre>
* throw new RequestParamsException(ParsingFailureException.of(ParsingFailureException.Type.NUMBER_PARSING_FAILURE)); * throw new RequestParamsException(ParsingFailureException.of(ParsingFailureException.Type.NUMBER_PARSING_FAILURE));
* </pre> * </pre>
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -21,11 +21,10 @@ package xyz.zhouxy.plusone.commons.exception.business;
* *
* <p> * <p>
* 业务异常 * 业务异常
* </p>
* *
* <p> * <p>
* <b>NOTE: 通常表示业务中的意外情况用户错误输入缺失必填字段用户余额不足等</b> * <b>NOTE: 通常表示业务中的意外情况用户错误输入缺失必填字段用户余额不足等</b>
* </p> *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0
*/ */

View File

@ -26,11 +26,10 @@ import xyz.zhouxy.plusone.commons.exception.MultiTypesException;
* *
* <p> * <p>
* 用户输入内容非法 * 用户输入内容非法
* </p>
* *
* <p> * <p>
* <b>NOTE: 属业务异常</b> * <b>NOTE: 属业务异常</b>
* </p> *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0
*/ */

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.exception.business;
* *
* <p> * <p>
* 用户请求参数错误 * 用户请求参数错误
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -15,18 +15,17 @@
*/ */
/** /**
* <h2>异常<h2> * <h2>异常</h2>
* *
* <h3>1. {@link MultiTypesException} - 多类型异常</h3> * <h3>1. {@link MultiTypesException} - 多类型异常</h3>
* <p> * <p>
* 异常在不同场景下被抛出可以用不同的枚举值表示不同的场景类型 * 异常在不同场景下被抛出可以用不同的枚举值表示不同的场景类型
* </p> *
* <p> * <p>
* 异常实现 {@link MultiTypesException} {@link MultiTypesException#getType} 方法返回对应的场景类型 * 异常实现 {@link MultiTypesException} {@link MultiTypesException#getType} 方法返回对应的场景类型
* </p> *
* <p> * <p>
* 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType}其中的工厂方法用于创建对应类型的异常 * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType}其中的工厂方法用于创建对应类型的异常
* </p>
* *
* <pre> * <pre>
* public final class LoginException * public final class LoginException
@ -57,7 +56,7 @@
* *
* // ... * // ...
* *
* public enum Type implements ExceptionType<LoginException> { * public enum Type implements ExceptionType&lt;LoginException&gt; {
* DEFAULT("00", "当前会话未登录"), * DEFAULT("00", "当前会话未登录"),
* NOT_TOKEN("10", "未提供token"), * NOT_TOKEN("10", "未提供token"),
* INVALID_TOKEN("20", "token无效"), * INVALID_TOKEN("20", "token无效"),
@ -113,7 +112,6 @@
* <pre> * <pre>
* throw LoginException.Type.TOKEN_TIMEOUT.create(); * throw LoginException.Type.TOKEN_TIMEOUT.create();
* </pre> * </pre>
* </p>
* *
* <h3>2. 业务异常</h3> * <h3>2. 业务异常</h3>
* 预设常见的业务异常可继承 {@link BizException} 自定义业务异常 * 预设常见的业务异常可继承 {@link BizException} 自定义业务异常

View File

@ -21,13 +21,12 @@ package xyz.zhouxy.plusone.commons.exception.system;
* *
* <p> * <p>
* 当数据操作的结果不符合预期时抛出 * 当数据操作的结果不符合预期时抛出
* </p>
* *
* <p> * <p>
* 比如当一个 insert update 操作时预计影响数据库中的一行数据但结果却影响了零条数据或多条数据 * 比如当一个 insert update 操作时预计影响数据库中的一行数据但结果却影响了零条数据或多条数据
* 当出现这种始料未及的诡异情况时抛出 {@link DataOperationResultException} 并回滚事务 * 当出现这种始料未及的诡异情况时抛出 {@link DataOperationResultException} 并回滚事务
* 后续需要排查原因 * 后续需要排查原因
* </p> *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0
*/ */

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.exception.system;
* *
* <p> * <p>
* 在无法找到可访问的 Mac 地址时抛出 * 在无法找到可访问的 Mac 地址时抛出
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.exception.system;
* *
* <p> * <p>
* 通常表示应用代码存在问题或因环境问题引发异常 * 通常表示应用代码存在问题或因环境问题引发异常
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -24,7 +24,6 @@ import com.google.common.annotations.Beta;
* <p> * <p>
* 一个特殊的 {@link java.util.function.UnaryOperator} * 一个特殊的 {@link java.util.function.UnaryOperator}
* 表示对 {@code boolean} 值的一元操作 * 表示对 {@code boolean} 值的一元操作
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -24,7 +24,6 @@ import com.google.common.annotations.Beta;
* <p> * <p>
* 一个特殊的 {@link java.util.function.UnaryOperator} * 一个特殊的 {@link java.util.function.UnaryOperator}
* 表示对 {@code char} 的一元操作 * 表示对 {@code char} 的一元操作
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.function;
* *
* <p> * <p>
* 表示一个无入参无返回值的操作可抛出异常 * 表示一个无入参无返回值的操作可抛出异常
* </p>
* *
* @param <E> 可抛出的异常类型 * @param <E> 可抛出的异常类型
* *

View File

@ -24,7 +24,6 @@ import java.util.function.Supplier;
* *
* <p> * <p>
* 返回 {@code Optional&lt;T&gt;} 对象 * 返回 {@code Optional&lt;T&gt;} 对象
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -23,7 +23,6 @@ import java.util.function.Predicate;
* *
* <p> * <p>
* {@link Predicate} 相关操作 * {@link Predicate} 相关操作
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.function;
* *
* <p> * <p>
* 允许抛出异常的消费操作是一个特殊的 {@link java.util.function.Consumer} * 允许抛出异常的消费操作是一个特殊的 {@link java.util.function.Consumer}
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -20,7 +20,6 @@ package xyz.zhouxy.plusone.commons.function;
* *
* <p> * <p>
* 接收一个参数并返回一个结果可以抛出异常 * 接收一个参数并返回一个结果可以抛出异常
* </p>
* *
* @param <T> 入参类型 * @param <T> 入参类型
* @param <R> 返回结果类型 * @param <R> 返回结果类型

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.function;
* *
* <p> * <p>
* 接收一个参数返回一个布尔值可抛出异常 * 接收一个参数返回一个布尔值可抛出异常
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -21,7 +21,6 @@ package xyz.zhouxy.plusone.commons.function;
* *
* <p> * <p>
* 允许抛出异常的 Supplier 接口 * 允许抛出异常的 Supplier 接口
* </p>
* *
* @param <T> 结果类型 * @param <T> 结果类型
* @param <E> 异常类型 * @param <E> 异常类型

View File

@ -20,7 +20,6 @@
* <h3>1. PredicateTools</h3> * <h3>1. PredicateTools</h3>
* <p> * <p>
* {@link PredicateTools} 用于 {@link java.util.function.Predicate} 的相关操作 * {@link PredicateTools} 用于 {@link java.util.function.Predicate} 的相关操作
* </p>
* *
* <h3>2. Functional interfaces</h3> * <h3>2. Functional interfaces</h3>
* <p> * <p>
@ -39,7 +38,6 @@
* | Optional | ToOptionalBiFunction | Optional&lt;R&gt; apply(T,U) | * | Optional | ToOptionalBiFunction | Optional&lt;R&gt; apply(T,U) |
* | Optional | ToOptionalFunction | Optional&lt;R&gt; apply(T) | * | Optional | ToOptionalFunction | Optional&lt;R&gt; apply(T) |
* </pre> * </pre>
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */

View File

@ -164,7 +164,7 @@ public class JSR310TypeAdapters {
* *
* <p> * <p>
* 使用 {@link DateTimeFormatter#ISO_INSTANT} 进行 {@link Instant} 的序列化与反序列化 * 使用 {@link DateTimeFormatter#ISO_INSTANT} 进行 {@link Instant} 的序列化与反序列化
* </p> *
*/ */
public static final class InstantTypeAdapter extends TypeAdapter<Instant> { public static final class InstantTypeAdapter extends TypeAdapter<Instant> {

View File

@ -40,7 +40,6 @@ import xyz.zhouxy.plusone.commons.util.StringTools;
* *
* <p> * <p>
* 中国第二代居民身份证号 * 中国第二代居民身份证号
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -37,7 +37,6 @@ import xyz.zhouxy.plusone.commons.util.StringTools;
* <p> * <p>
* 根据传入的 {@code size} {@code pageNum} * 根据传入的 {@code size} {@code pageNum}
* 提供 {@code getOffset} 方法计算 SQL 语句中 {@code offset} 的值 * 提供 {@code getOffset} 方法计算 SQL 语句中 {@code offset} 的值
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @see PagingParams * @see PagingParams

View File

@ -22,12 +22,12 @@
* 分页组件由 {@link PagingAndSortingQueryParams} 作为入参 * 分页组件由 {@link PagingAndSortingQueryParams} 作为入参
* 因为分页必须伴随着排序不然可能出现同一个对象重复出现在不同页有的对象不被查询到的情况 * 因为分页必须伴随着排序不然可能出现同一个对象重复出现在不同页有的对象不被查询到的情况
* 所以分页查询的入参必须包含排序条件 * 所以分页查询的入参必须包含排序条件
* </p> *
* <p> * <p>
* 用户可继承 {@link PagingAndSortingQueryParams} * 用户可继承 {@link PagingAndSortingQueryParams}
* 构建自己的分页查询入参需在构造器中调用 {@link PagingAndSortingQueryParams} 的构造器传入一个 Map 作为白名单 * 构建自己的分页查询入参需在构造器中调用 {@link PagingAndSortingQueryParams} 的构造器传入一个 Map 作为白名单
* key 是供前端指定用于排序的属性名value 是对应数据库中的字段名只有在白名单中指定的属性名才允许作为排序条件 * key 是供前端指定用于排序的属性名value 是对应数据库中的字段名只有在白名单中指定的属性名才允许作为排序条件
* </p> *
* <p> * <p>
* {@link PagingAndSortingQueryParams} 包含三个主要的属性 * {@link PagingAndSortingQueryParams} 包含三个主要的属性
* <ul> * <ul>
@ -37,21 +37,20 @@
* </ul> * </ul>
* 其中 orderBy 是一个 List可以指定多个排序条件每个排序条件是一个字符串 * 其中 orderBy 是一个 List可以指定多个排序条件每个排序条件是一个字符串
* 格式为属性名-ASC属性名-DESC分别表示升序和降序 * 格式为属性名-ASC属性名-DESC分别表示升序和降序
* </p> *
* <p> * <p>
* 比如前端传入的 orderBy ["name-ASC","age-DESC"]意味着要按 name 进行升序name 相同的情况下则按 age 进行降序 * 比如前端传入的 orderBy ["name-ASC","age-DESC"]意味着要按 name 进行升序name 相同的情况下则按 age 进行降序
* </p> *
* <p> * <p>
* 使用时调用 {@link PagingAndSortingQueryParams#buildPagingParams()} 方法获取分页参数 {@link PagingParams} * 使用时调用 {@link PagingAndSortingQueryParams#buildPagingParams()} 方法获取分页参数 {@link PagingParams}
* </p> *
* <p> * <p>
* 分页结果可以存放到 {@link PageResult} 作为出参 * 分页结果可以存放到 {@link PageResult} 作为出参
* </p>
* *
* <h3>2. {@link UnifiedResponse}</h3> * <h3>2. {@link UnifiedResponse}</h3>
* <p> * <p>
* {@link UnifiedResponse} 对返回给前端的数据进行封装包含 codemessagedata * {@link UnifiedResponse} 对返回给前端的数据进行封装包含 codemessagedata
* </p> *
* <p> * <p>
* 可使用 {@link UnifiedResponses} 快速构建 {@link UnifiedResponse} 对象 * 可使用 {@link UnifiedResponses} 快速构建 {@link UnifiedResponse} 对象
* {@link UnifiedResponses} 默认的成功代码为 "2000000" * {@link UnifiedResponses} 默认的成功代码为 "2000000"
@ -60,7 +59,6 @@
* 中所示范的继承 {@link UnifiedResponses} 实现自己的工厂类 * 中所示范的继承 {@link UnifiedResponses} 实现自己的工厂类
* 自定义 SUCCESS_CODE DEFAULT_SUCCESS_MSG 和工厂方法 * 自定义 SUCCESS_CODE DEFAULT_SUCCESS_MSG 和工厂方法
* <a href="http://zhouxy.xyz:3000/plusone/plusone-commons/issues/22">issue#22</a> * <a href="http://zhouxy.xyz:3000/plusone/plusone-commons/issues/22">issue#22</a>
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */

View File

@ -18,7 +18,6 @@
* <h2>业务建模组件</h2> * <h2>业务建模组件</h2>
* <p> * <p>
* 包含业务建模可能用到的性别身份证等元素也包含 DTO 相关类如分页查询参数响应结果分页结果等 * 包含业务建模可能用到的性别身份证等元素也包含 DTO 相关类如分页查询参数响应结果分页结果等
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */

View File

@ -15,7 +15,7 @@
*/ */
/** /**
* <h2>时间 API<h2> * <h2>时间 API</h2>
* *
* <h3>1. 季度 API</h3> * <h3>1. 季度 API</h3>
* *

View File

@ -33,7 +33,6 @@ import javax.annotation.Nullable;
* *
* <p> * <p>
* 数组工具类 * 数组工具类
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -29,7 +29,6 @@ import xyz.zhouxy.plusone.commons.exception.system.DataOperationResultException;
* *
* <p> * <p>
* 本工具类不封装过多判断逻辑鼓励充分使用项目中的工具类进行逻辑判断 * 本工具类不封装过多判断逻辑鼓励充分使用项目中的工具类进行逻辑判断
* </p>
* *
* <pre> * <pre>
* AssertTools.checkArgument(StringUtils.hasText(str), "The argument cannot be blank."); * AssertTools.checkArgument(StringUtils.hasText(str), "The argument cannot be blank.");

View File

@ -28,7 +28,6 @@ import xyz.zhouxy.plusone.commons.annotation.StaticFactoryMethod;
* *
* <p> * <p>
* BigDecimal 工具类 * BigDecimal 工具类
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -215,7 +215,6 @@ public class DateTimeTools {
* <p> * <p>
* 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上还是同一时间戳 * 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上还是同一时间戳
* 只是不同时区的表示 * 只是不同时区的表示
* </p>
* *
* @param timeMillis 时间戳 * @param timeMillis 时间戳
* @param zone 时区 * @param zone 时区
@ -230,7 +229,6 @@ public class DateTimeTools {
* <p> * <p>
* 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上还是同一时间戳 * 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上还是同一时间戳
* 只是不同时区的表示 * 只是不同时区的表示
* </p>
* *
* @param dateTime {@link Date} 对象 * @param dateTime {@link Date} 对象
* @param zone 时区 * @param zone 时区
@ -245,7 +243,6 @@ public class DateTimeTools {
* <p> * <p>
* 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上表示的还是还是同一时间戳的时间 * 传入不同 {@link ZoneId}获取到的 {@link ZonedDateTime} 对象实际上表示的还是还是同一时间戳的时间
* 只是不同时区的表示 * 只是不同时区的表示
* </p>
* *
* @param dateTime {@link Date} 对象 * @param dateTime {@link Date} 对象
* @param timeZone 时区 * @param timeZone 时区

View File

@ -34,7 +34,7 @@ import xyz.zhouxy.plusone.commons.annotation.StaticFactoryMethod;
* 参考 <a href="https://lostechies.com/jimmybogard/2008/08/12/enumeration-classes/">Enumeration classes</a> * 参考 <a href="https://lostechies.com/jimmybogard/2008/08/12/enumeration-classes/">Enumeration classes</a>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @deprecated 设计 Enumeration 的灵感来自于 .net 社区因为 C# 的枚举不带行为 * @deprecated 设计 Enumeration 的灵感来自于 .net 社区因为 C&num; 的枚举不带行为
* Java 的枚举可以带行为故大多数情况下不需要这种设计 * Java 的枚举可以带行为故大多数情况下不需要这种设计
*/ */
@Deprecated @Deprecated

View File

@ -26,7 +26,6 @@ import java.util.concurrent.ConcurrentHashMap;
* *
* <p> * <p>
* 生成 UUID 修改版雪花IDSeata 版本 * 生成 UUID 修改版雪花IDSeata 版本
* </p>
* *
* @see UUID * @see UUID
* @see IdWorker * @see IdWorker

View File

@ -34,7 +34,7 @@ import xyz.zhouxy.plusone.commons.exception.system.NoAvailableMacFoundException;
* <li>每个机器线程安全地生成序列前面加上机器的id这样就不会与其它机器的id相冲突</li> * <li>每个机器线程安全地生成序列前面加上机器的id这样就不会与其它机器的id相冲突</li>
* <li>时间戳作为序列的预留位它更像是应用启动时最开始的序列的一部分在一个时间戳里生成 4096 id 之后直接生成下一个时间戳的 id</li> * <li>时间戳作为序列的预留位它更像是应用启动时最开始的序列的一部分在一个时间戳里生成 4096 id 之后直接生成下一个时间戳的 id</li>
* </ol> * </ol>
* </p> *
* <p> * <p>
* 详情见以下介绍 * 详情见以下介绍
* <ul> * <ul>
@ -43,7 +43,7 @@ import xyz.zhouxy.plusone.commons.exception.system.NoAvailableMacFoundException;
* <li><a href="https://juejin.cn/post/7264387737276203065">在开源项目中看到一个改良版的雪花算法现在它是你的了</a></li> * <li><a href="https://juejin.cn/post/7264387737276203065">在开源项目中看到一个改良版的雪花算法现在它是你的了</a></li>
* <li><a href="https://juejin.cn/post/7265516484029743138">关于若干读者阅读改良版雪花算法后提出的几个共性问题的回复</a></li> * <li><a href="https://juejin.cn/post/7265516484029743138">关于若干读者阅读改良版雪花算法后提出的几个共性问题的回复</a></li>
* </ul> * </ul>
* </p> *
*/ */
public class IdWorker { public class IdWorker {

View File

@ -45,7 +45,6 @@ public class OptionalTools {
* <p> * <p>
* 包装类为 {@code null} 表示值的缺失转为 {@link OptionalInt} * 包装类为 {@code null} 表示值的缺失转为 {@link OptionalInt}
* {@link OptionalInt#empty()} 表示值的缺失 * {@link OptionalInt#empty()} 表示值的缺失
* </p>
* *
* @param value 包装对象 * @param value 包装对象
* @return {@link OptionalInt} 实例 * @return {@link OptionalInt} 实例
@ -58,7 +57,6 @@ public class OptionalTools {
* {@code Optional<Integer>} 对象转为 {@link OptionalInt} 对象 * {@code Optional<Integer>} 对象转为 {@link OptionalInt} 对象
* <p> * <p>
* {@code Optional<Integer>} 将整数包装了两次改为使用 {@link OptionalInt} 包装其中的整数数据 * {@code Optional<Integer>} 将整数包装了两次改为使用 {@link OptionalInt} 包装其中的整数数据
* </p>
* *
* @param optionalObj {@code Optional<Integer>} 对象 * @param optionalObj {@code Optional<Integer>} 对象
* @return {@link OptionalInt} 实例 * @return {@link OptionalInt} 实例
@ -72,7 +70,6 @@ public class OptionalTools {
* <p> * <p>
* 包装类为 {@code null} 表示值的缺失转为 {@link OptionalLong} * 包装类为 {@code null} 表示值的缺失转为 {@link OptionalLong}
* {@link OptionalLong#empty()} 表示值的缺失 * {@link OptionalLong#empty()} 表示值的缺失
* </p>
* *
* @param value 包装对象 * @param value 包装对象
* @return {@link OptionalLong} 实例 * @return {@link OptionalLong} 实例
@ -85,7 +82,6 @@ public class OptionalTools {
* {@code Optional<Long>} 转为 {@link OptionalLong} * {@code Optional<Long>} 转为 {@link OptionalLong}
* <p> * <p>
* {@code Optional<Long>} 将整数包装了两次改为使用 {@link OptionalLong} 包装其中的整数数据 * {@code Optional<Long>} 将整数包装了两次改为使用 {@link OptionalLong} 包装其中的整数数据
* </p>
* *
* @param optionalObj 包装对象 * @param optionalObj 包装对象
* @return {@link OptionalLong} 实例 * @return {@link OptionalLong} 实例
@ -99,7 +95,6 @@ public class OptionalTools {
* <p> * <p>
* 包装类为 {@code null} 表示值的缺失转为 {@link OptionalDouble} * 包装类为 {@code null} 表示值的缺失转为 {@link OptionalDouble}
* {@link OptionalDouble#empty()} 表示值的缺失 * {@link OptionalDouble#empty()} 表示值的缺失
* </p>
* *
* @param value 包装对象 * @param value 包装对象
* @return {@link OptionalDouble} 实例 * @return {@link OptionalDouble} 实例
@ -112,7 +107,6 @@ public class OptionalTools {
* {@code Optional<Double>} 转为 {@link OptionalDouble} * {@code Optional<Double>} 转为 {@link OptionalDouble}
* <p> * <p>
* {@code Optional<Double>} 将整数包装了两次改为使用 {@link OptionalDouble} 包装其中的整数数据 * {@code Optional<Double>} 将整数包装了两次改为使用 {@link OptionalDouble} 包装其中的整数数据
* </p>
* *
* @param optionalObj 包装对象 * @param optionalObj 包装对象
* @return {@link OptionalDouble} 实例 * @return {@link OptionalDouble} 实例

View File

@ -26,7 +26,7 @@ import java.util.concurrent.ThreadLocalRandom;
* 随机工具类 * 随机工具类
* <p> * <p>
* 建议调用方自行维护 Random 对象 * 建议调用方自行维护 Random 对象
* </p> *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */
public final class RandomTools { public final class RandomTools {

View File

@ -31,7 +31,6 @@ import xyz.zhouxy.plusone.commons.constant.PatternConsts;
* *
* <p> * <p>
* 字符串工具类 * 字符串工具类
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
* @since 1.0.0 * @since 1.0.0

View File

@ -18,7 +18,6 @@
* <h2>工具类</h2> * <h2>工具类</h2>
* <p> * <p>
* 包含树构建器{@link TreeBuilder}断言工具{@link AssertTools}ID 生成器{@link IdGenerator}及其它实用工具类 * 包含树构建器{@link TreeBuilder}断言工具{@link AssertTools}ID 生成器{@link IdGenerator}及其它实用工具类
* </p>
* *
* @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a> * @author <a href="http://zhouxy.xyz:3000/ZhouXY108">ZhouXY</a>
*/ */