adf$a.smali
.class Ldxoptimizer/adf$a;
.super Ljava/lang/Object;
.source "KeyValueStorageImpl.java"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Ldxoptimizer/adf;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = "a"
.end annotation
# instance fields
.field volatile a:Z
.field volatile b:[Ldxoptimizer/acv;
.field final synthetic c:Ldxoptimizer/adf;
# direct methods
.method constructor <init>(Ldxoptimizer/adf;)V
.registers 3
.prologue
.line 292
iput-object p1, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 295
const/4 v0, 0x0
iput-boolean v0, p0, Ldxoptimizer/adf$a;->a:Z
.line 297
const/16 v0, 0xc8
new-array v0, v0, [Ldxoptimizer/acv;
iput-object v0, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
return-void
.end method
# virtual methods
.method public a()I
.registers 13
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">()I"
}
.end annotation
.prologue
const/4 v5, 0x1
const/4 v6, 0x0
const/4 v3, 0x0
.line 330
.line 334
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v7, v0, Ldxoptimizer/adf;->s:Ljava/lang/Object;
monitor-enter v7
.line 335
:try_start_8
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v0, v0, Ldxoptimizer/adf;->A:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->isEmpty()Z
move-result v0
if-eqz v0, :cond_15
.line 336
monitor-exit v7
move v2, v3
.line 406
:cond_14
:goto_14
return v2
:cond_15
move v0, v3
.line 339
:goto_16
iget-object v1, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
array-length v1, v1
if-ge v0, v1, :cond_23
.line 340
iget-object v1, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
const/4 v2, 0x0
aput-object v2, v1, v0
.line 339
add-int/lit8 v0, v0, 0x1
goto :goto_16
.line 343
:cond_23
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v0, v0, Ldxoptimizer/adf;->A:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->values()Ljava/util/Collection;
move-result-object v0
.line 345
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v4
move-object v1, v6
move v2, v3
:goto_31
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_5d
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ldxoptimizer/acv;
.line 346
iget-object v8, v0, Ldxoptimizer/acv;->a:Ljava/lang/String;
if-nez v8, :cond_4f
iget-object v8, v0, Ldxoptimizer/acv;->c:Ldxoptimizer/ade$b;
if-nez v8, :cond_4f
iget-object v8, v0, Ldxoptimizer/acv;->b:Ljava/lang/Object;
instance-of v8, v8, Ljava/lang/Runnable;
if-eqz v8, :cond_4f
move v1, v2
:goto_4c
move v2, v1
move-object v1, v0
.line 356
goto :goto_31
.line 349
:cond_4f
const/16 v8, 0xc8
if-ge v2, v8, :cond_5d
.line 350
iget-object v8, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
aput-object v0, v8, v2
.line 351
add-int/lit8 v0, v2, 0x1
move-object v11, v1
move v1, v0
move-object v0, v11
goto :goto_4c
.line 358
:cond_5d
if-eqz v1, :cond_67
.line 359
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v0, v0, Ldxoptimizer/adf;->A:Ljava/util/HashMap;
const/4 v4, 0x0
invoke-virtual {v0, v4}, Ljava/util/HashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
:cond_67
move v0, v3
.line 361
:goto_68
if-ge v0, v2, :cond_7c
.line 362
iget-object v4, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
aget-object v4, v4, v0
.line 363
if-eqz v4, :cond_79
.line 364
iget-object v8, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v8, v8, Ldxoptimizer/adf;->A:Ljava/util/HashMap;
iget-object v4, v4, Ldxoptimizer/acv;->a:Ljava/lang/String;
invoke-virtual {v8, v4}, Ljava/util/HashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 361
:cond_79
add-int/lit8 v0, v0, 0x1
goto :goto_68
.line 368
:cond_7c
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v0, v0, Ldxoptimizer/adf;->A:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->isEmpty()Z
move-result v0
if-nez v0, :cond_bb
move v4, v5
.line 369
:goto_87
monitor-exit v7
:try_end_88
.catchall {:try_start_8 .. :try_end_88} :catchall_bd
.line 372
:goto_88
if-ge v3, v2, :cond_c3
.line 373
iget-object v0, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
aget-object v0, v0, v3
.line 374
if-eqz v0, :cond_b8
.line 375
iget-object v7, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v8, v0, Ldxoptimizer/acv;->a:Ljava/lang/String;
invoke-virtual {v7, v8}, Ldxoptimizer/adf;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v7
.line 376
iput-object v7, v0, Ldxoptimizer/acv;->d:Ljava/lang/String;
.line 378
iget-object v8, v0, Ldxoptimizer/acv;->b:Ljava/lang/Object;
sget-object v9, Ldxoptimizer/ade;->a:Ljava/lang/Object;
if-eq v8, v9, :cond_c0
.line 379
iget-object v8, v0, Ldxoptimizer/acv;->c:Ldxoptimizer/ade$b;
iget-object v9, v0, Ldxoptimizer/acv;->b:Ljava/lang/Object;
invoke-interface {v8, v9}, Ldxoptimizer/ade$b;->a(Ljava/lang/Object;)[B
move-result-object v8
.line 380
iget-object v9, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v9, v9, Ldxoptimizer/adf;->v:Ldxoptimizer/acw;
iget-object v10, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
invoke-static {v10, v7}, Ldxoptimizer/adf;->a(Ldxoptimizer/adf;Ljava/lang/String;)[B
move-result-object v7
invoke-virtual {v9, v8, v7}, Ldxoptimizer/acw;->a([B[B)[B
move-result-object v7
.line 382
iput-object v7, v0, Ldxoptimizer/acv;->e:[B
.line 372
:cond_b8
:goto_b8
add-int/lit8 v3, v3, 0x1
goto :goto_88
:cond_bb
move v4, v3
.line 368
goto :goto_87
.line 369
:catchall_bd
move-exception v0
:try_start_be
monitor-exit v7
:try_end_bf
.catchall {:try_start_be .. :try_end_bf} :catchall_bd
throw v0
.line 384
:cond_c0
iput-object v6, v0, Ldxoptimizer/acv;->e:[B
goto :goto_b8
.line 389
:cond_c3
sget v0, Ldxoptimizer/adf;->p:I
add-int/2addr v0, v2
sput v0, Ldxoptimizer/adf;->p:I
.line 392
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v0, v0, Ldxoptimizer/adf;->u:Ldxoptimizer/adb;
iget-object v3, p0, Ldxoptimizer/adf$a;->b:[Ldxoptimizer/acv;
invoke-virtual {v0, v3, v2}, Ldxoptimizer/adb;->a([Ldxoptimizer/acv;I)Z
.line 394
if-eqz v1, :cond_da
.line 396
:try_start_d3
iget-object v0, v1, Ldxoptimizer/acv;->b:Ljava/lang/Object;
check-cast v0, Ljava/lang/Runnable;
invoke-interface {v0}, Ljava/lang/Runnable;->run()V
:try_end_da
.catch Ljava/lang/Throwable; {:try_start_d3 .. :try_end_da} :catch_e3
.line 401
:cond_da
:goto_da
if-eqz v4, :cond_14
.line 403
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
invoke-virtual {v0, v5}, Ldxoptimizer/adf;->a(Z)Z
goto/16 :goto_14
.line 397
:catch_e3
move-exception v0
goto :goto_da
.end method
.method public run()V
.registers 9
.prologue
const/4 v1, 0x0
.line 301
.line 303
:try_start_1
sget-object v0, Ldxoptimizer/adf;->o:Ldxoptimizer/adi;
const/4 v2, 0x0
invoke-virtual {v0, v2}, Ldxoptimizer/adi;->a(I)V
.line 304
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v2, v0, Ldxoptimizer/adf;->C:Ljava/lang/Object;
monitor-enter v2
:try_end_c
.catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_c} :catch_90
.catchall {:try_start_1 .. :try_end_c} :catchall_a4
.line 305
const/4 v0, 0x1
:try_start_d
iput-boolean v0, p0, Ldxoptimizer/adf$a;->a:Z
.line 306
monitor-exit v2
:try_end_10
.catchall {:try_start_d .. :try_end_10} :catchall_8d
.line 307
:try_start_10
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-boolean v0, v0, Ldxoptimizer/adf;->w:Z
if-eqz v0, :cond_b5
iget-object v0, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-boolean v0, v0, Ldxoptimizer/adf;->y:Z
if-eqz v0, :cond_b5
.line 308
invoke-virtual {p0}, Ldxoptimizer/adf$a;->a()I
:try_end_1f
.catch Ljava/lang/Throwable; {:try_start_10 .. :try_end_1f} :catch_90
.catchall {:try_start_10 .. :try_end_1f} :catchall_a4
move-result v0
.line 313
:goto_20
iput-boolean v1, p0, Ldxoptimizer/adf$a;->a:Z
.line 315
sget-object v2, Ldxoptimizer/adf;->o:Ldxoptimizer/adi;
invoke-virtual {v2, v1}, Ldxoptimizer/adi;->b(I)J
move-result-wide v2
.line 317
sget-boolean v4, Ldxoptimizer/zj;->a:Z
if-eqz v4, :cond_8c
.line 318
sget v4, Ldxoptimizer/adf;->p:I
if-lez v4, :cond_8c
if-lez v0, :cond_8c
.line 319
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "write "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
iget-object v5, p0, Ldxoptimizer/adf$a;->c:Ldxoptimizer/adf;
iget-object v5, v5, Ldxoptimizer/adf;->q:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, ":"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, " items in "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, "ms, avg="
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
int-to-long v6, v0
div-long/2addr v2, v6
invoke-virtual {v4, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, "ms, totalAvg="
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
sget-object v2, Ldxoptimizer/adf;->o:Ldxoptimizer/adi;
.line 321
invoke-virtual {v2, v1}, Ldxoptimizer/adi;->c(I)F
move-result v1
sget v2, Ldxoptimizer/adf;->p:I
int-to-float v2, v2
div-float/2addr v1, v2
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "ms, totalCount="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
sget v1, Ldxoptimizer/adf;->p:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 319
invoke-static {v0}, Ldxoptimizer/zm;->a(Ljava/lang/String;)V
.line 327
:cond_8c
:goto_8c
return-void
.line 306
:catchall_8d
move-exception v0
:try_start_8e
monitor-exit v2
:try_end_8f
.catchall {:try_start_8e .. :try_end_8f} :catchall_8d
:try_start_8f
throw v0
:try_end_90
.catch Ljava/lang/Throwable; {:try_start_8f .. :try_end_90} :catch_90
.catchall {:try_start_8f .. :try_end_90} :catchall_a4
.line 310
:catch_90
move-exception v0
.line 311
:try_start_91
invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
:try_end_94
.catchall {:try_start_91 .. :try_end_94} :catchall_a4
.line 313
iput-boolean v1, p0, Ldxoptimizer/adf$a;->a:Z
.line 315
sget-object v0, Ldxoptimizer/adf;->o:Ldxoptimizer/adi;
invoke-virtual {v0, v1}, Ldxoptimizer/adi;->b(I)J
.line 317
sget-boolean v0, Ldxoptimizer/zj;->a:Z
if-eqz v0, :cond_8c
.line 318
sget v0, Ldxoptimizer/adf;->p:I
if-lez v0, :cond_8c
goto :goto_8c
.line 313
:catchall_a4
move-exception v0
iput-boolean v1, p0, Ldxoptimizer/adf$a;->a:Z
.line 315
sget-object v2, Ldxoptimizer/adf;->o:Ldxoptimizer/adi;
invoke-virtual {v2, v1}, Ldxoptimizer/adi;->b(I)J
.line 317
sget-boolean v1, Ldxoptimizer/zj;->a:Z
if-eqz v1, :cond_b4
.line 318
sget v1, Ldxoptimizer/adf;->p:I
if-lez v1, :cond_b4
.line 326
:cond_b4
throw v0
:cond_b5
move v0, v1
goto/16 :goto_20
.end method