DefaultPoolExecutor.smali

.class public Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;
.super Ljava/util/concurrent/ThreadPoolExecutor;
.source "DefaultPoolExecutor.java"


# static fields
.field private static final CPU_COUNT:I

.field private static final INIT_THREAD_COUNT:I

.field private static final MAX_THREAD_COUNT:I

.field private static final SURPLUS_THREAD_LIFE:J = 0x1eL

.field private static instance:Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .line 1
    invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Runtime;->availableProcessors()I

    move-result v0

    sput v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->CPU_COUNT:I

    .line 2
    sget v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->CPU_COUNT:I

    add-int/lit8 v0, v0, 0x1

    sput v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->INIT_THREAD_COUNT:I

    .line 3
    sget v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->INIT_THREAD_COUNT:I

    sput v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->MAX_THREAD_COUNT:I

    return-void
.end method

.method private constructor <init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;)V
    .registers 17
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(IIJ",
            "Ljava/util/concurrent/TimeUnit;",
            "Ljava/util/concurrent/BlockingQueue<",
            "Ljava/lang/Runnable;",
            ">;",
            "Ljava/util/concurrent/ThreadFactory;",
            ")V"
        }
    .end annotation

    .line 1
    new-instance v8, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor$1;

    invoke-direct {v8}, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor$1;-><init>()V

    move-object v0, p0

    move v1, p1

    move v2, p2

    move-wide v3, p3

    move-object v5, p5

    move-object v6, p6

    move-object/from16 v7, p7

    invoke-direct/range {v0 .. v8}, Ljava/util/concurrent/ThreadPoolExecutor;-><init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;Ljava/util/concurrent/RejectedExecutionHandler;)V

    return-void
.end method

.method public static getInstance()Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;
    .registers 10

    .line 1
    sget-object v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->instance:Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    if-nez v0, :cond_2c

    .line 2
    const-class v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    monitor-enter v0

    .line 3
    :try_start_7
    sget-object v1, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->instance:Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    if-nez v1, :cond_27

    .line 4
    new-instance v1, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    sget v3, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->INIT_THREAD_COUNT:I

    sget v4, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->MAX_THREAD_COUNT:I

    const-wide/16 v5, 0x1e

    sget-object v7, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    new-instance v8, Ljava/util/concurrent/ArrayBlockingQueue;

    const/16 v2, 0x40

    invoke-direct {v8, v2}, Ljava/util/concurrent/ArrayBlockingQueue;-><init>(I)V

    new-instance v9, Lcom/alibaba/android/arouter/thread/DefaultThreadFactory;

    invoke-direct {v9}, Lcom/alibaba/android/arouter/thread/DefaultThreadFactory;-><init>()V

    move-object v2, v1

    invoke-direct/range {v2 .. v9}, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;-><init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;)V

    sput-object v1, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->instance:Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    .line 5
    :cond_27
    monitor-exit v0

    goto :goto_2c

    :catchall_29
    move-exception v1

    monitor-exit v0
    :try_end_2b
    .catchall {:try_start_7 .. :try_end_2b} :catchall_29

    throw v1

    .line 6
    :cond_2c
    :goto_2c
    sget-object v0, Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;->instance:Lcom/alibaba/android/arouter/thread/DefaultPoolExecutor;

    return-object v0
.end method


# virtual methods
.method protected afterExecute(Ljava/lang/Runnable;Ljava/lang/Throwable;)V
    .registers 5

    .line 1
    invoke-super {p0, p1, p2}, Ljava/util/concurrent/ThreadPoolExecutor;->afterExecute(Ljava/lang/Runnable;Ljava/lang/Throwable;)V

    if-nez p2, :cond_1f

    .line 2
    instance-of v0, p1, Ljava/util/concurrent/Future;

    if-eqz v0, :cond_1f

    .line 3
    :try_start_9
    check-cast p1, Ljava/util/concurrent/Future;

    invoke-interface {p1}, Ljava/util/concurrent/Future;->get()Ljava/lang/Object;
    :try_end_e
    .catch Ljava/util/concurrent/CancellationException; {:try_start_9 .. :try_end_e} :catch_1d
    .catch Ljava/util/concurrent/ExecutionException; {:try_start_9 .. :try_end_e} :catch_17
    .catch Ljava/lang/InterruptedException; {:try_start_9 .. :try_end_e} :catch_f

    goto :goto_1f

    .line 4
    :catch_f
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object p1

    invoke-virtual {p1}, Ljava/lang/Thread;->interrupt()V

    goto :goto_1f

    :catch_17
    move-exception p1

    .line 5
    invoke-virtual {p1}, Ljava/util/concurrent/ExecutionException;->getCause()Ljava/lang/Throwable;

    move-result-object p2

    goto :goto_1f

    :catch_1d
    move-exception p1

    move-object p2, p1

    :cond_1f
    :goto_1f
    if-eqz p2, :cond_5d

    .line 6
    sget-object p1, Lcom/alibaba/android/arouter/launcher/ARouter;->logger:Lcom/alibaba/android/arouter/facade/template/ILogger;

    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "Running task appeared exception! Thread ["

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/Thread;->getName()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, "], because ["

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {p2}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, "]\n"

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {p2}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;

    move-result-object p2

    invoke-static {p2}, Lcom/alibaba/android/arouter/utils/TextUtils;->formatStackTrace([Ljava/lang/StackTraceElement;)Ljava/lang/String;

    move-result-object p2

    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p2

    const-string v0, "ARouter::"

    invoke-interface {p1, v0, p2}, Lcom/alibaba/android/arouter/facade/template/ILogger;->warning(Ljava/lang/String;Ljava/lang/String;)V

    :cond_5d
    return-void
.end method