8 Commits
dev ... v0.0.3

Author SHA1 Message Date
5770a41893 Merge pull request 'v0.0.3' (#8) from dev into master
Reviewed-on: #8
2026-04-27 15:50:11 +00:00
a919cf0a52 Merge pull request 'v0.0.2' (#7) from dev into master
Reviewed-on: #7
2026-01-19 09:24:19 +00:00
5612d6a24a Merge pull request 'v0.0.2' (#6) from dev into master
Reviewed-on: #6
2026-01-19 09:14:14 +00:00
db530c1fed Merge pull request 'v0.0.2' (#5) from dev into master
Reviewed-on: #5
2026-01-19 09:08:52 +00:00
1fe9cf7b77 Merge pull request 'v0.0.2' (#4) from dev into master
Reviewed-on: #4
2026-01-19 09:03:06 +00:00
0d21b154ca Merge pull request 'v0.0.2' (#3) from dev into master
Reviewed-on: #3
2026-01-19 08:59:04 +00:00
acba4c11d9 Merge pull request 'v0.0.2' (#2) from dev into master
Reviewed-on: #2
2026-01-19 06:43:33 +00:00
d21fba0fc1 Merge pull request 'v0.0.2' (#1) from dev into master
Reviewed-on: #1
2026-01-19 06:30:23 +00:00
2 changed files with 26 additions and 46 deletions

View File

@@ -6,7 +6,7 @@
<groupId>com.imyeyu.java</groupId>
<artifactId>timi-java</artifactId>
<version>0.0.4</version>
<version>0.0.3</version>
<packaging>jar</packaging>
<properties>

View File

@@ -3,11 +3,9 @@ package com.imyeyu.java.thread;
import com.imyeyu.java.bean.Callback;
import com.imyeyu.java.bean.CallbackArg;
import com.imyeyu.java.bean.timi.TimiException;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import java.util.concurrent.TimeUnit;
@@ -42,41 +40,6 @@ public class AsyncRetryExecutor {
@Getter
private volatile boolean isRunning = false;
/**
* 任务
*
* @author 夜雨
* @since 2025-11-06 23:37
*/
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public static class Task {
/** 必填回调方法 */
private Callback callback;
/** 最大重试次数,-1 为无限重试 */
@Builder.Default
private int maxRetry = DEFAULT_MAX_RETRY;
/** 重试间隔毫秒数 */
@Builder.Default
private long retryInterval = DEFAULT_RETRY_INTERVAL;
/** 线程名前缀 */
@Builder.Default
private String threadNamePrefix = DEFAULT_THREAD_NAME_PREFIX;
/** 是否设置为守护线程 */
@Builder.Default
private boolean daemon = DEFAULT_DAEMON;
/** 重试耗尽时的异常回调 */
private CallbackArg<Exception> onRetryExhausted;
}
/**
* 根据构建器参数创建异步重试执行器
*
@@ -99,9 +62,7 @@ public class AsyncRetryExecutor {
}
if (0 < task.maxRetry && task.maxRetry < retryCount) {
// 超过重试次数
if (task.onRetryExhausted != null) {
task.onRetryExhausted.handler(e);
}
break;
}
// 重试
@@ -118,13 +79,32 @@ public class AsyncRetryExecutor {
}
/**
* 使用默认参数创建执行
* 构造
*
* @param task 任务
* @return 执行器实例
* @author 夜雨
* @since 2025-11-06 23:37
*/
public static AsyncRetryExecutor create(Task task) {
return new AsyncRetryExecutor(task);
@Data
@Builder
public static class Task {
/** 必填回调方法 */
private Callback callback;
/** 最大重试次数,-1 为无限重试 */
private int maxRetry = DEFAULT_MAX_RETRY;
/** 重试间隔毫秒数 */
private long retryInterval = DEFAULT_RETRY_INTERVAL;
/** 线程名前缀 */
private String threadNamePrefix = DEFAULT_THREAD_NAME_PREFIX;
/** 是否设置为守护线程 */
private boolean daemon = DEFAULT_DAEMON;
/** 重试耗尽时的异常回调 */
private CallbackArg<Exception> onRetryExhausted;
}
/**