ab.smali
.class public final Lcom/tencent/bugly/proguard/ab;
.super Ljava/lang/Thread;
.source "BUGLY"
# instance fields
.field private a:Z
.field private b:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lcom/tencent/bugly/proguard/aa;",
">;"
}
.end annotation
.end field
.field private c:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lcom/tencent/bugly/proguard/ac;",
">;"
}
.end annotation
.end field
.field private d:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList",
"<",
"Lcom/tencent/bugly/proguard/aa;",
">;"
}
.end annotation
.end field
# direct methods
.method public constructor <init>()V
.registers 2
.prologue
.line 18
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
.line 21
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/tencent/bugly/proguard/ab;->a:Z
.line 22
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
.line 23
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
.line 24
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/tencent/bugly/proguard/ab;->d:Ljava/util/ArrayList;
return-void
.end method
.method private a(Landroid/os/Handler;J)V
.registers 10
.prologue
const/4 v0, 0x0
.line 66
if-nez p1, :cond_b
.line 67
const-string v1, "addThread handler should not be null"
new-array v0, v0, [Ljava/lang/Object;
invoke-static {v1, v0}, Lcom/tencent/bugly/proguard/x;->e(Ljava/lang/String;[Ljava/lang/Object;)Z
.line 82
:goto_a
return-void
.line 70
:cond_b
invoke-virtual {p1}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;
move-result-object v1
invoke-virtual {v1}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
move v1, v0
.line 72
:goto_18
:try_start_18
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-ge v1, v0, :cond_4b
.line 73
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/bugly/proguard/aa;
invoke-virtual {v0}, Lcom/tencent/bugly/proguard/aa;->d()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;
move-result-object v3
invoke-virtual {v3}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_58
.line 74
const-string v0, "addThread fail ,this thread has been added in monitor queue"
const/4 v1, 0x0
new-array v1, v1, [Ljava/lang/Object;
invoke-static {v0, v1}, Lcom/tencent/bugly/proguard/x;->e(Ljava/lang/String;[Ljava/lang/Object;)Z
:try_end_46
.catch Ljava/lang/Exception; {:try_start_18 .. :try_end_46} :catch_47
goto :goto_a
.line 78
:catch_47
move-exception v0
.line 79
invoke-static {v0}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
.line 81
:cond_4b
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
new-instance v1, Lcom/tencent/bugly/proguard/aa;
const-wide/16 v4, 0x1388
invoke-direct {v1, p1, v2, v4, v5}, Lcom/tencent/bugly/proguard/aa;-><init>(Landroid/os/Handler;Ljava/lang/String;J)V
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_a
.line 72
:cond_58
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_18
.end method
.method private e()I
.registers 4
.prologue
const/4 v0, 0x0
.line 147
move v1, v0
move v2, v0
.line 149
:goto_3
:try_start_3
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-ge v1, v0, :cond_23
.line 150
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/bugly/proguard/aa;
.line 151
invoke-virtual {v0}, Lcom/tencent/bugly/proguard/aa;->c()I
move-result v0
invoke-static {v2, v0}, Ljava/lang/Math;->max(II)I
:try_end_1a
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_1a} :catch_1f
move-result v2
.line 149
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_3
.line 153
:catch_1f
move-exception v0
.line 154
invoke-static {v0}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
.line 156
:cond_23
return v2
.end method
# virtual methods
.method public final a()V
.registers 5
.prologue
.line 32
new-instance v0, Landroid/os/Handler;
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
const-wide/16 v2, 0x1388
invoke-direct {p0, v0, v2, v3}, Lcom/tencent/bugly/proguard/ab;->a(Landroid/os/Handler;J)V
.line 33
return-void
.end method
.method public final a(Lcom/tencent/bugly/proguard/ac;)V
.registers 4
.prologue
.line 163
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_11
.line 164
const-string v0, "addThreadMonitorListeners fail ,this threadMonitorListener has been added in monitor queue"
const/4 v1, 0x0
new-array v1, v1, [Ljava/lang/Object;
invoke-static {v0, v1}, Lcom/tencent/bugly/proguard/x;->c(Ljava/lang/String;[Ljava/lang/Object;)Z
.line 168
:goto_10
return-void
.line 167
:cond_11
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_10
.end method
.method public final b()V
.registers 6
.prologue
const/4 v0, 0x0
.line 41
move v1, v0
:goto_2
:try_start_2
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-ge v1, v0, :cond_47
.line 42
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/bugly/proguard/aa;
invoke-virtual {v0}, Lcom/tencent/bugly/proguard/aa;->d()Ljava/lang/String;
move-result-object v0
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v2
invoke-virtual {v2}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_3f
.line 43
const-string/jumbo v0, "remove handler::%s"
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
iget-object v4, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v4, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v4
aput-object v4, v2, v3
invoke-static {v0, v2}, Lcom/tencent/bugly/proguard/x;->c(Ljava/lang/String;[Ljava/lang/Object;)Z
.line 44
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->remove(I)Ljava/lang/Object;
:try_end_3f
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_3f} :catch_43
.line 41
:cond_3f
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_2
.line 47
:catch_43
move-exception v0
.line 48
invoke-static {v0}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
.line 50
:cond_47
return-void
.end method
.method public final b(Lcom/tencent/bugly/proguard/ac;)V
.registers 3
.prologue
.line 174
iget-object v0, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
.line 175
return-void
.end method
.method public final c()Z
.registers 3
.prologue
const/4 v0, 0x1
.line 117
iput-boolean v0, p0, Lcom/tencent/bugly/proguard/ab;->a:Z
.line 118
invoke-virtual {p0}, Lcom/tencent/bugly/proguard/ab;->isAlive()Z
move-result v1
if-nez v1, :cond_b
.line 119
const/4 v0, 0x0
.line 126
:goto_a
return v0
.line 122
:cond_b
:try_start_b
invoke-virtual {p0}, Lcom/tencent/bugly/proguard/ab;->interrupt()V
:try_end_e
.catch Ljava/lang/Exception; {:try_start_b .. :try_end_e} :catch_f
goto :goto_a
.line 123
:catch_f
move-exception v1
.line 124
invoke-static {v1}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
goto :goto_a
.end method
.method public final d()Z
.registers 3
.prologue
const/4 v0, 0x0
.line 133
.line 134
invoke-virtual {p0}, Lcom/tencent/bugly/proguard/ab;->isAlive()Z
move-result v1
if-eqz v1, :cond_8
.line 143
:goto_7
return v0
.line 138
:cond_8
:try_start_8
invoke-virtual {p0}, Lcom/tencent/bugly/proguard/ab;->start()V
:try_end_b
.catch Ljava/lang/Exception; {:try_start_8 .. :try_end_b} :catch_d
.line 139
const/4 v0, 0x1
goto :goto_7
.line 140
:catch_d
move-exception v1
.line 141
invoke-static {v1}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
goto :goto_7
.end method
.method public final run()V
.registers 15
.prologue
const-wide/16 v10, 0x7d0
const/4 v4, 0x1
const/4 v7, 0x0
.line 194
:cond_4
:goto_4
iget-boolean v2, p0, Lcom/tencent/bugly/proguard/ab;->a:Z
if-nez v2, :cond_bf
move v3, v7
.line 197
:goto_9
:try_start_9
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
if-ge v3, v2, :cond_20
.line 198
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v2, v3}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/bugly/proguard/aa;
.line 199
invoke-virtual {v2}, Lcom/tencent/bugly/proguard/aa;->a()V
.line 197
add-int/lit8 v2, v3, 0x1
move v3, v2
goto :goto_9
.line 201
:cond_20
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v8
move-wide v2, v10
.line 202
:goto_25
const-wide/16 v12, 0x0
cmp-long v5, v2, v12
if-lez v5, :cond_3c
invoke-virtual {p0}, Lcom/tencent/bugly/proguard/ab;->isInterrupted()Z
move-result v5
if-nez v5, :cond_3c
.line 203
invoke-static {v2, v3}, Lcom/tencent/bugly/proguard/ab;->sleep(J)V
.line 204
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v2
sub-long/2addr v2, v8
sub-long v2, v10, v2
goto :goto_25
.line 206
:cond_3c
invoke-direct {p0}, Lcom/tencent/bugly/proguard/ab;->e()I
move-result v2
.line 207
if-eqz v2, :cond_4
if-eq v2, v4, :cond_4
.line 210
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->d:Ljava/util/ArrayList;
invoke-virtual {v2}, Ljava/util/ArrayList;->clear()V
move v3, v7
.line 211
:goto_4a
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
if-ge v3, v2, :cond_71
.line 212
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->b:Ljava/util/List;
invoke-interface {v2, v3}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/bugly/proguard/aa;
.line 213
invoke-virtual {v2}, Lcom/tencent/bugly/proguard/aa;->b()Z
move-result v5
if-eqz v5, :cond_6d
.line 214
iget-object v5, p0, Lcom/tencent/bugly/proguard/ab;->d:Ljava/util/ArrayList;
invoke-virtual {v5, v2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 215
const-wide v8, 0x7fffffffffffffffL
invoke-virtual {v2, v8, v9}, Lcom/tencent/bugly/proguard/aa;->a(J)V
.line 211
:cond_6d
add-int/lit8 v2, v3, 0x1
move v3, v2
goto :goto_4a
:cond_71
move v6, v7
move v5, v7
.line 219
:goto_73
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->d:Ljava/util/ArrayList;
invoke-virtual {v2}, Ljava/util/ArrayList;->size()I
move-result v2
if-ge v6, v2, :cond_4
.line 220
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->d:Ljava/util/ArrayList;
invoke-virtual {v2, v6}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v2
move-object v0, v2
check-cast v0, Lcom/tencent/bugly/proguard/aa;
move-object v3, v0
move v8, v7
.line 221
:goto_86
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
if-ge v8, v2, :cond_a2
.line 222
iget-object v2, p0, Lcom/tencent/bugly/proguard/ab;->c:Ljava/util/List;
invoke-interface {v2, v8}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/bugly/proguard/ac;
invoke-interface {v2, v3}, Lcom/tencent/bugly/proguard/ac;->a(Lcom/tencent/bugly/proguard/aa;)Z
move-result v2
if-eqz v2, :cond_c0
move v2, v4
.line 221
:goto_9d
add-int/lit8 v5, v8, 0x1
move v8, v5
move v5, v2
goto :goto_86
.line 226
:cond_a2
if-nez v5, :cond_af
.line 227
invoke-virtual {v3}, Lcom/tencent/bugly/proguard/aa;->f()V
const-string v2, "although thread is blocked ,may not be anr error,so restore handler check wait time and restart check main thread"
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Object;
invoke-static {v2, v3}, Lcom/tencent/bugly/proguard/x;->c(Ljava/lang/String;[Ljava/lang/Object;)Z
:try_end_af
.catch Ljava/lang/Exception; {:try_start_9 .. :try_end_af} :catch_b3
.catch Ljava/lang/OutOfMemoryError; {:try_start_9 .. :try_end_af} :catch_b9
.line 219
:cond_af
add-int/lit8 v2, v6, 0x1
move v6, v2
goto :goto_73
.line 230
:catch_b3
move-exception v2
.line 231
invoke-static {v2}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
goto/16 :goto_4
.line 232
:catch_b9
move-exception v2
.line 233
invoke-static {v2}, Lcom/tencent/bugly/proguard/x;->b(Ljava/lang/Throwable;)Z
goto/16 :goto_4
.line 236
:cond_bf
return-void
:cond_c0
move v2, v5
goto :goto_9d
.end method