summaryrefslogtreecommitdiff
path: root/src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java
diff options
context:
space:
mode:
authorKeuin <[email protected]>2020-04-27 17:42:07 +0800
committerkeuin <[email protected]>2020-04-27 17:42:07 +0800
commit7444c2b1f281b5b147717ba2a2ed6798c66a057b (patch)
tree8d8952b2f3aaf1e497e8667b80fc59b91536c822 /src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java
parent33857f4bc061d8dc01a6d9d10e108da7cd7c6d18 (diff)
Resized the logo to reduce plugin size.1.3.3-dev1.3.2-dev
Refactored code for a better implementation of async and blocking task.
Diffstat (limited to 'src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java')
-rw-r--r--src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java b/src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java
new file mode 100644
index 0000000..f1a19de
--- /dev/null
+++ b/src/main/java/com/keuin/kbackupfabric/operation/abstracts/AbstractAsyncOperation.java
@@ -0,0 +1,53 @@
+package com.keuin.kbackupfabric.operation.abstracts;
+
+public abstract class AbstractAsyncOperation extends AbstractSerializedOperation {
+
+ private final Thread thread;
+ private final String name;
+ private final Object sync = new Object();
+
+ protected AbstractAsyncOperation(String name) {
+ this.name = name;
+ this.thread = new Thread(this::async, name);
+ }
+
+ /**
+ * Start the worker thread.
+ *
+ * @return true if succeed starting, false if already started.
+ */
+ @Override
+ protected final boolean operate() {
+ synchronized (sync) {
+ if (thread.isAlive())
+ return false;
+ if (!sync())
+ return false;
+ thread.start();
+ return true;
+ }
+ }
+
+ /**
+ * Implement your async operation here.
+ * When this method returns, the operation must finish.
+ */
+ protected abstract void async();
+
+ /**
+ * If necessary, implement your sync operations here.
+ * It will be invoked before starting the async thread.
+ */
+ protected boolean sync() {
+ return true;
+ }
+
+ public final String getName() {
+ return name;
+ }
+
+ @Override
+ public String toString() {
+ return "operation " + name;
+ }
+}