e.smali

.class public Lcom/fulishe/shadow/taskqueue/e;
.super Ljava/lang/Object;
.source ""


# static fields
.field public static final a:Ljava/lang/String; = "e"

.field public static b:Ljava/util/concurrent/atomic/AtomicInteger;

.field public static volatile c:Lcom/fulishe/shadow/taskqueue/e;

.field public static volatile d:Z


# instance fields
.field public volatile e:Z

.field public final f:Ljava/util/concurrent/PriorityBlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/PriorityBlockingQueue",
            "<",
            "Lcom/fulishe/shadow/taskqueue/d;",
            ">;"
        }
    .end annotation
.end field

.field public final g:Ljava/util/concurrent/PriorityBlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/PriorityBlockingQueue",
            "<",
            "Lcom/fulishe/shadow/taskqueue/d;",
            ">;"
        }
    .end annotation
.end field

.field public h:[Lcom/fulishe/shadow/taskqueue/b;

.field public i:Lcom/fulishe/shadow/taskqueue/c;

.field public j:I

.field public volatile k:J

.field public volatile l:J


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

    new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V

    sput-object v0, Lcom/fulishe/shadow/taskqueue/e;->b:Ljava/util/concurrent/atomic/AtomicInteger;

    const/4 v0, 0x1

    sput-boolean v0, Lcom/fulishe/shadow/taskqueue/e;->d:Z

    return-void
.end method

.method public constructor <init>()V
    .registers 3

    const/4 v0, 0x2

    const/4 v1, 0x1

    invoke-direct {p0, v0, v1}, Lcom/fulishe/shadow/taskqueue/e;-><init>(II)V

    return-void
.end method

.method public constructor <init>(II)V
    .registers 7

    const-wide/16 v2, 0x0

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

    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/fulishe/shadow/taskqueue/e;->e:Z

    new-instance v0, Ljava/util/concurrent/PriorityBlockingQueue;

    invoke-direct {v0}, Ljava/util/concurrent/PriorityBlockingQueue;-><init>()V

    iput-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->f:Ljava/util/concurrent/PriorityBlockingQueue;

    new-instance v0, Ljava/util/concurrent/PriorityBlockingQueue;

    invoke-direct {v0}, Ljava/util/concurrent/PriorityBlockingQueue;-><init>()V

    iput-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->g:Ljava/util/concurrent/PriorityBlockingQueue;

    iput-wide v2, p0, Lcom/fulishe/shadow/taskqueue/e;->k:J

    iput-wide v2, p0, Lcom/fulishe/shadow/taskqueue/e;->l:J

    iput p1, p0, Lcom/fulishe/shadow/taskqueue/e;->j:I

    mul-int/lit8 v0, p1, 0x3

    new-array v0, v0, [Lcom/fulishe/shadow/taskqueue/b;

    iput-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    return-void
.end method

.method public static a()Lcom/fulishe/shadow/taskqueue/e;
    .registers 2

    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->c:Lcom/fulishe/shadow/taskqueue/e;

    if-nez v0, :cond_13

    const-class v1, Lcom/fulishe/shadow/taskqueue/e;

    monitor-enter v1

    :try_start_7
    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->c:Lcom/fulishe/shadow/taskqueue/e;

    if-nez v0, :cond_12

    new-instance v0, Lcom/fulishe/shadow/taskqueue/e;

    invoke-direct {v0}, Lcom/fulishe/shadow/taskqueue/e;-><init>()V

    sput-object v0, Lcom/fulishe/shadow/taskqueue/e;->c:Lcom/fulishe/shadow/taskqueue/e;

    :cond_12
    monitor-exit v1
    :try_end_13
    .catchall {:try_start_7 .. :try_end_13} :catchall_16

    :cond_13
    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->c:Lcom/fulishe/shadow/taskqueue/e;

    return-object v0

    :catchall_16
    move-exception v0

    :try_start_17
    monitor-exit v1
    :try_end_18
    .catchall {:try_start_17 .. :try_end_18} :catchall_16

    throw v0
.end method

.method public static b()I
    .registers 1

    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->b:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I

    move-result v0

    return v0
.end method


# virtual methods
.method public declared-synchronized a(Lcom/fulishe/shadow/taskqueue/a;)V
    .registers 4

    monitor-enter p0

    if-eqz p1, :cond_1c

    :try_start_3
    invoke-static {}, Lcom/fulishe/shadow/taskqueue/e;->b()I

    move-result v0

    invoke-virtual {p1, v0}, Lcom/fulishe/shadow/taskqueue/a;->a(I)Lcom/fulishe/shadow/taskqueue/a;

    iget-boolean v0, p0, Lcom/fulishe/shadow/taskqueue/e;->e:Z

    if-nez v0, :cond_11

    invoke-virtual {p0}, Lcom/fulishe/shadow/taskqueue/e;->c()V

    :cond_11
    invoke-virtual {p1}, Lcom/fulishe/shadow/taskqueue/a;->c()Z

    move-result v0

    if-eqz v0, :cond_1e

    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->f:Ljava/util/concurrent/PriorityBlockingQueue;

    invoke-virtual {v0, p1}, Ljava/util/concurrent/PriorityBlockingQueue;->add(Ljava/lang/Object;)Z
    :try_end_1c
    .catchall {:try_start_3 .. :try_end_1c} :catchall_2a

    :cond_1c
    :goto_1c
    monitor-exit p0

    return-void

    :cond_1e
    :try_start_1e
    invoke-virtual {p1}, Lcom/fulishe/shadow/taskqueue/a;->e()Lcom/xinmeng/shadow/interfaces/l;

    move-result-object v0

    sget-object v1, Lcom/xinmeng/shadow/interfaces/l;->a:Lcom/xinmeng/shadow/interfaces/l;

    if-ne v0, v1, :cond_2d

    invoke-static {p1}, Lcom/fulishe/shadow/taskqueue/a/a;->a(Ljava/lang/Runnable;)V
    :try_end_29
    .catchall {:try_start_1e .. :try_end_29} :catchall_2a

    goto :goto_1c

    :catchall_2a
    move-exception v0

    monitor-exit p0

    throw v0

    :cond_2d
    :try_start_2d
    invoke-virtual {p1}, Lcom/fulishe/shadow/taskqueue/a;->g()V

    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->g:Ljava/util/concurrent/PriorityBlockingQueue;

    invoke-virtual {v0, p1}, Ljava/util/concurrent/PriorityBlockingQueue;->add(Ljava/lang/Object;)Z
    :try_end_35
    .catchall {:try_start_2d .. :try_end_35} :catchall_2a

    goto :goto_1c
.end method

.method public declared-synchronized c()V
    .registers 6

    monitor-enter p0

    :try_start_1
    invoke-virtual {p0}, Lcom/fulishe/shadow/taskqueue/e;->d()V

    new-instance v0, Lcom/fulishe/shadow/taskqueue/c;

    iget-object v1, p0, Lcom/fulishe/shadow/taskqueue/e;->f:Ljava/util/concurrent/PriorityBlockingQueue;

    iget-object v2, p0, Lcom/fulishe/shadow/taskqueue/e;->g:Ljava/util/concurrent/PriorityBlockingQueue;

    invoke-direct {v0, v1, v2}, Lcom/fulishe/shadow/taskqueue/c;-><init>(Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/BlockingQueue;)V

    iput-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->i:Lcom/fulishe/shadow/taskqueue/c;

    invoke-virtual {v0}, Ljava/lang/Thread;->start()V

    const/4 v0, 0x0

    :goto_13
    iget v1, p0, Lcom/fulishe/shadow/taskqueue/e;->j:I

    if-ge v0, v1, :cond_2c

    new-instance v1, Lcom/fulishe/shadow/taskqueue/b;

    iget-object v2, p0, Lcom/fulishe/shadow/taskqueue/e;->g:Ljava/util/concurrent/PriorityBlockingQueue;

    const-string v3, "ApiDispatcher-Thread"

    const-string v4, "ApiDispatcher"

    invoke-direct {v1, v2, v3, v4}, Lcom/fulishe/shadow/taskqueue/b;-><init>(Ljava/util/concurrent/BlockingQueue;Ljava/lang/String;Ljava/lang/String;)V

    iget-object v2, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    aput-object v1, v2, v0

    invoke-virtual {v1}, Ljava/lang/Thread;->start()V

    add-int/lit8 v0, v0, 0x1

    goto :goto_13

    :cond_2c
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/fulishe/shadow/taskqueue/e;->e:Z
    :try_end_2f
    .catchall {:try_start_1 .. :try_end_2f} :catchall_31

    monitor-exit p0

    return-void

    :catchall_31
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized d()V
    .registers 4

    const/4 v0, 0x0

    monitor-enter p0

    const/4 v1, 0x0

    :try_start_3
    iput-boolean v1, p0, Lcom/fulishe/shadow/taskqueue/e;->e:Z

    iget-object v1, p0, Lcom/fulishe/shadow/taskqueue/e;->i:Lcom/fulishe/shadow/taskqueue/c;

    if-eqz v1, :cond_c

    invoke-virtual {v1}, Lcom/fulishe/shadow/taskqueue/c;->a()V

    :cond_c
    :goto_c
    iget-object v1, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    array-length v2, v1

    if-ge v0, v2, :cond_22

    aget-object v2, v1, v0

    if-eqz v2, :cond_1f

    aget-object v1, v1, v0

    invoke-virtual {v1}, Lcom/fulishe/shadow/taskqueue/b;->a()V

    iget-object v1, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    const/4 v2, 0x0

    aput-object v2, v1, v0
    :try_end_1f
    .catchall {:try_start_3 .. :try_end_1f} :catchall_24

    :cond_1f
    add-int/lit8 v0, v0, 0x1

    goto :goto_c

    :cond_22
    monitor-exit p0

    return-void

    :catchall_24
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized e()V
    .registers 9

    const/4 v0, 0x0

    monitor-enter p0

    :try_start_2
    sget-boolean v1, Lcom/fulishe/shadow/taskqueue/e;->d:Z

    if-eqz v1, :cond_2a

    sget-object v1, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    const-string v2, "handleExpandRequestQueueSize"

    invoke-static {v1, v2}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    iget-wide v4, p0, Lcom/fulishe/shadow/taskqueue/e;->k:J

    cmp-long v1, v4, v2

    if-lez v1, :cond_19

    iput-wide v2, p0, Lcom/fulishe/shadow/taskqueue/e;->k:J

    :cond_19
    iget-wide v4, p0, Lcom/fulishe/shadow/taskqueue/e;->k:J

    sub-long v4, v2, v4

    const-wide/16 v6, 0x3e8

    cmp-long v1, v4, v6

    if-gtz v1, :cond_2c

    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    const-string v1, "handleExpandRequestQueueSize (now - mLastExpandRequestQueueTime) <= ApiThread.ENQUEUE_EXPIRE"

    invoke-static {v0, v1}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_2a
    .catchall {:try_start_2 .. :try_end_2a} :catchall_77

    :cond_2a
    :goto_2a
    monitor-exit p0

    return-void

    :cond_2c
    :try_start_2c
    iput-wide v2, p0, Lcom/fulishe/shadow/taskqueue/e;->k:J

    move v1, v0

    :goto_2f
    iget-object v2, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    array-length v2, v2

    if-ge v1, v2, :cond_2a

    iget-object v2, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    aget-object v2, v2, v1

    if-nez v2, :cond_74

    add-int/lit8 v0, v0, 0x1

    iget v2, p0, Lcom/fulishe/shadow/taskqueue/e;->j:I

    if-gt v0, v2, :cond_2a

    new-instance v2, Lcom/fulishe/shadow/taskqueue/b;

    iget-object v3, p0, Lcom/fulishe/shadow/taskqueue/e;->g:Ljava/util/concurrent/PriorityBlockingQueue;

    const-string v4, "ApiDispatcher-Thread"

    const-string v5, "ApiDispatcher"

    invoke-direct {v2, v3, v4, v5}, Lcom/fulishe/shadow/taskqueue/b;-><init>(Ljava/util/concurrent/BlockingQueue;Ljava/lang/String;Ljava/lang/String;)V

    sget-object v3, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    new-instance v4, Ljava/lang/StringBuilder;

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

    const-string v5, "apiDispatcher : "

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

    move-result-object v4

    invoke-virtual {v2}, Ljava/lang/Thread;->toString()Ljava/lang/String;

    move-result-object v5

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

    move-result-object v4

    const-string v5, " create"

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

    move-result-object v4

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

    move-result-object v4

    invoke-static {v3, v4}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V

    iget-object v3, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    aput-object v2, v3, v1

    invoke-virtual {v2}, Ljava/lang/Thread;->start()V
    :try_end_74
    .catchall {:try_start_2c .. :try_end_74} :catchall_77

    :cond_74
    add-int/lit8 v1, v1, 0x1

    goto :goto_2f

    :catchall_77
    move-exception v0

    :try_start_78
    invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
    :try_end_7b
    .catchall {:try_start_78 .. :try_end_7b} :catchall_7c

    goto :goto_2a

    :catchall_7c
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized f()V
    .registers 11

    const/4 v2, 0x1

    const/4 v1, 0x0

    monitor-enter p0

    :try_start_3
    sget-boolean v0, Lcom/fulishe/shadow/taskqueue/e;->d:Z

    if-eqz v0, :cond_2b

    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    const-string v3, "handleShrinkRequestQueueSize"

    invoke-static {v0, v3}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v4

    iget-wide v6, p0, Lcom/fulishe/shadow/taskqueue/e;->l:J

    cmp-long v0, v6, v4

    if-lez v0, :cond_1a

    iput-wide v4, p0, Lcom/fulishe/shadow/taskqueue/e;->l:J

    :cond_1a
    iget-wide v6, p0, Lcom/fulishe/shadow/taskqueue/e;->l:J

    sub-long v6, v4, v6

    const-wide/16 v8, 0x7d0

    cmp-long v0, v6, v8

    if-gtz v0, :cond_2d

    sget-object v0, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    const-string v1, "handleShrinkRequestQueueSize (now - mLastShrinkRequestQueueTime) <= ApiDispatcher.SHRINK_EXPIRE"

    invoke-static {v0, v1}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_2b
    .catchall {:try_start_3 .. :try_end_2b} :catchall_74

    :cond_2b
    :goto_2b
    monitor-exit p0

    return-void

    :cond_2d
    :try_start_2d
    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    array-length v0, v0

    add-int/lit8 v0, v0, -0x1

    move v3, v0

    move v0, v2

    :goto_34
    iget v6, p0, Lcom/fulishe/shadow/taskqueue/e;->j:I

    if-lt v3, v6, :cond_4b

    iget-object v6, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    aget-object v6, v6, v3

    if-eqz v6, :cond_45

    invoke-virtual {v6}, Lcom/fulishe/shadow/taskqueue/b;->b()Z

    move-result v7

    if-eqz v7, :cond_45

    move v2, v1

    :cond_45
    if-eqz v6, :cond_48

    move v0, v1

    :cond_48
    add-int/lit8 v3, v3, -0x1

    goto :goto_34

    :cond_4b
    iput-wide v4, p0, Lcom/fulishe/shadow/taskqueue/e;->l:J

    if-eqz v2, :cond_51

    if-eqz v0, :cond_7c

    :cond_51
    sget-object v1, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "handleShrinkRequestQueueSize shouldShrink = "

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

    move-result-object v3

    invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    move-result-object v2

    const-string v3, " allNull = "

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

    move-result-object v2

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

    move-result-object v0

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_73
    .catchall {:try_start_2d .. :try_end_73} :catchall_74

    goto :goto_2b

    :catchall_74
    move-exception v0

    :try_start_75
    invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
    :try_end_78
    .catchall {:try_start_75 .. :try_end_78} :catchall_79

    goto :goto_2b

    :catchall_79
    move-exception v0

    monitor-exit p0

    throw v0

    :cond_7c
    :try_start_7c
    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    array-length v0, v0

    add-int/lit8 v0, v0, -0x1

    move v1, v0

    :goto_82
    iget v0, p0, Lcom/fulishe/shadow/taskqueue/e;->j:I
    :try_end_84
    .catchall {:try_start_7c .. :try_end_84} :catchall_74

    if-lt v1, v0, :cond_2b

    :try_start_86
    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    aget-object v0, v0, v1

    if-eqz v0, :cond_c4

    invoke-virtual {v0}, Ljava/lang/Thread;->getState()Ljava/lang/Thread$State;

    move-result-object v2

    sget-object v3, Ljava/lang/Thread$State;->RUNNABLE:Ljava/lang/Thread$State;

    if-eq v2, v3, :cond_c4

    invoke-virtual {v0}, Lcom/fulishe/shadow/taskqueue/b;->b()Z

    move-result v2

    if-nez v2, :cond_c4

    sget-object v2, Lcom/fulishe/shadow/taskqueue/e;->a:Ljava/lang/String;

    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "apiDispatcher : "

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

    move-result-object v3

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

    move-result-object v4

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

    move-result-object v3

    const-string v4, " quit"

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

    move-result-object v3

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

    move-result-object v3

    invoke-static {v2, v3}, Lcom/fulishe/shadow/base/p;->a(Ljava/lang/String;Ljava/lang/String;)V

    invoke-virtual {v0}, Lcom/fulishe/shadow/taskqueue/b;->a()V

    iget-object v0, p0, Lcom/fulishe/shadow/taskqueue/e;->h:[Lcom/fulishe/shadow/taskqueue/b;

    const/4 v2, 0x0

    aput-object v2, v0, v1
    :try_end_c4
    .catchall {:try_start_86 .. :try_end_c4} :catchall_c8

    :cond_c4
    :goto_c4
    add-int/lit8 v0, v1, -0x1

    move v1, v0

    goto :goto_82

    :catchall_c8
    move-exception v0

    :try_start_c9
    invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
    :try_end_cc
    .catchall {:try_start_c9 .. :try_end_cc} :catchall_74

    goto :goto_c4
.end method