b$b.smali
.class public final Lsg/bigo/apm/plugins/memoryinfo/b$b;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lsg/bigo/apm/plugins/memoryinfo/a;
# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
value = Lsg/bigo/apm/plugins/memoryinfo/b;-><init>(Lkotlin/f/a/b;)V
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x19
name = null
.end annotation
# instance fields
.field final synthetic a:Lsg/bigo/apm/plugins/memoryinfo/b;
# direct methods
.method constructor <init>(Lsg/bigo/apm/plugins/memoryinfo/b;)V
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()V"
}
.end annotation
.line 69
iput-object p1, p0, Lsg/bigo/apm/plugins/memoryinfo/b$b;->a:Lsg/bigo/apm/plugins/memoryinfo/b;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public final a(ILsg/bigo/apm/plugins/memoryinfo/b/d;Ljava/lang/OutOfMemoryError;)V
.registers 27
move/from16 v0, p1
move-object/from16 v1, p2
move-object/from16 v2, p3
const-string v3, "memoryInfo"
invoke-static {v1, v3}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
move-object/from16 v4, p0
.line 72
iget-object v5, v4, Lsg/bigo/apm/plugins/memoryinfo/b$b;->a:Lsg/bigo/apm/plugins/memoryinfo/b;
invoke-static {v5}, Lsg/bigo/apm/plugins/memoryinfo/b;->a(Lsg/bigo/apm/plugins/memoryinfo/b;)Lsg/bigo/apm/plugins/memoryinfo/c;
move-result-object v5
invoke-static {v1, v3}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 1057
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v6
const-wide/16 v8, 0x0
if-nez v2, :cond_40
.line 1022
iget-object v10, v5, Lsg/bigo/apm/plugins/memoryinfo/c;->a:Ljava/util/Map;
invoke-static/range {p1 .. p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v11
invoke-interface {v10, v11}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v10
if-nez v10, :cond_2e
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
:cond_2e
check-cast v10, Ljava/lang/Number;
invoke-virtual {v10}, Ljava/lang/Number;->longValue()J
move-result-wide v10
sub-long v10, v6, v10
sget-object v12, Lsg/bigo/apm/plugins/memoryinfo/a/a;->a:Lsg/bigo/apm/plugins/memoryinfo/a/a;
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/a/a;->h()J
move-result-wide v12
cmp-long v14, v10, v12
if-ltz v14, :cond_63
.line 1026
:cond_40
iget-object v10, v5, Lsg/bigo/apm/plugins/memoryinfo/c;->a:Ljava/util/Map;
invoke-static/range {p1 .. p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v11
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
invoke-interface {v10, v11, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 1029
new-instance v6, Lsg/bigo/apm/plugins/memoryinfo/b/a;
invoke-direct {v6, v0, v1, v2}, Lsg/bigo/apm/plugins/memoryinfo/b/a;-><init>(ILsg/bigo/apm/plugins/memoryinfo/b/d;Ljava/lang/OutOfMemoryError;)V
check-cast v6, Lsg/bigo/apm/a/d;
.line 1058
sget-object v7, Lsg/bigo/apm/a;->d:Lsg/bigo/apm/a$b;
invoke-static {}, Lsg/bigo/apm/a$b;->a()Lsg/bigo/apm/a;
move-result-object v7
.line 2019
iget-object v7, v7, Lsg/bigo/apm/a;->c:Lsg/bigo/apm/c/b;
.line 3014
iget-object v5, v5, Lsg/bigo/apm/plugins/memoryinfo/c;->c:Lsg/bigo/apm/plugins/memoryinfo/b;
.line 1058
check-cast v5, Lsg/bigo/apm/a/a;
invoke-virtual {v7, v5, v6}, Lsg/bigo/apm/c/b;->a(Lsg/bigo/apm/a/a;Lsg/bigo/apm/a/d;)V
.line 73
:cond_63
sget-object v5, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->d:Lsg/bigo/apm/plugins/memoryinfo/hprof/b;
invoke-static {v1, v3}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 3061
sget-boolean v3, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->c:Z
if-eqz v3, :cond_1d4
sget-boolean v3, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->b:Z
if-nez v3, :cond_1d4
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;->a()Z
move-result v3
if-eqz v3, :cond_78
goto/16 :goto_1d4
.line 4013
:cond_78
iget v3, v1, Lsg/bigo/apm/plugins/memoryinfo/b/d;->a:I
int-to-double v5, v3
.line 4015
iget v3, v1, Lsg/bigo/apm/plugins/memoryinfo/b/d;->b:I
int-to-double v10, v3
.line 3064
invoke-static {v5, v6}, Ljava/lang/Double;->isNaN(D)Z
invoke-static {v10, v11}, Ljava/lang/Double;->isNaN(D)Z
div-double v16, v5, v10
.line 3065
sget-object v3, Lsg/bigo/apm/plugins/memoryinfo/a/a;->a:Lsg/bigo/apm/plugins/memoryinfo/a/a;
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/a/a;->j()D
move-result-wide v5
cmpg-double v3, v16, v5
if-ltz v3, :cond_1d4
.line 3069
invoke-static {}, Lsg/bigo/apm/b/b;->g()Z
move-result v3
const/4 v5, 0x1
if-nez v3, :cond_a3
if-ne v0, v5, :cond_1d4
if-eqz v2, :cond_a2
invoke-static/range {p3 .. p3}, Lsg/bigo/apm/plugins/memoryinfo/c/b;->a(Ljava/lang/OutOfMemoryError;)I
move-result v3
if-nez v3, :cond_1d4
goto :goto_a3
:cond_a2
return-void
:cond_a3
:goto_a3
const-string v3, "HprofController"
if-eq v0, v5, :cond_e8
.line 3072
sget-object v0, Lsg/bigo/apm/plugins/a/b$a;->a:Lsg/bigo/apm/plugins/a/b$a;
invoke-static {}, Lsg/bigo/apm/plugins/a/b$a;->a()V
.line 3073
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/a;->b:Lsg/bigo/apm/plugins/memoryinfo/c/a;
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/a;->b:Lsg/bigo/apm/plugins/memoryinfo/c/a;
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/a;->c()J
move-result-wide v6
const-wide/16 v10, 0x400
.line 3145
div-long/2addr v6, v10
long-to-double v10, v6
.line 5015
iget v0, v1, Lsg/bigo/apm/plugins/memoryinfo/b/d;->b:I
int-to-double v12, v0
.line 3074
invoke-static {v10, v11}, Ljava/lang/Double;->isNaN(D)Z
invoke-static {v12, v13}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v10, v12
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/a/a;->a:Lsg/bigo/apm/plugins/memoryinfo/a/a;
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/a/a;->j()D
move-result-wide v12
cmpg-double v0, v10, v12
if-gez v0, :cond_e9
.line 3075
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "java heap used not reach threshold after gc: "
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 6013
iget v1, v1, Lsg/bigo/apm/plugins/memoryinfo/b/d;->a:I
.line 3075
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " -> "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v3, v0}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
return-void
:cond_e8
move-wide v6, v8
.line 3079
:cond_e9
sput-boolean v5, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->b:Z
.line 3080
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/b/f;->a()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lkotlin/m/p;->e(Ljava/lang/String;)Ljava/lang/Long;
move-result-object v0
if-eqz v0, :cond_fa
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v10
goto :goto_fb
:cond_fa
move-wide v10, v8
.line 3081
:goto_fb
invoke-virtual/range {p2 .. p2}, Lsg/bigo/apm/plugins/memoryinfo/b/d;->toMap()Ljava/util/Map;
move-result-object v0
cmp-long v1, v6, v8
if-eqz v1, :cond_10c
.line 3083
invoke-static {v6, v7}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v1
const-string v6, "java_heap_used_after_gc"
invoke-interface {v0, v6, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 3085
:cond_10c
new-instance v1, Lcom/google/gson/f;
invoke-direct {v1}, Lcom/google/gson/f;-><init>()V
invoke-virtual {v1, v0}, Lcom/google/gson/f;->b(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
.line 3086
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
const-string v6, "onMemoryIssue: "
invoke-virtual {v6, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-static {v3, v1}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
const-string v1, "memoryInfoJson"
.line 3087
invoke-static {v0, v1}, Lkotlin/f/b/o;->a(Ljava/lang/Object;Ljava/lang/String;)V
if-eqz v2, :cond_12e
invoke-virtual/range {p3 .. p3}, Ljava/lang/OutOfMemoryError;->getMessage()Ljava/lang/String;
move-result-object v1
goto :goto_12f
:cond_12e
const/4 v1, 0x0
:goto_12f
move-object/from16 v18, v1
.line 6133
new-instance v1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/MemoryIssueStat;
const/16 v19, 0x0
const/16 v20, 0x0
const/16 v21, 0x30
const/16 v22, 0x0
move-object v12, v1
move-wide v13, v10
move-object v15, v0
invoke-direct/range {v12 .. v22}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/MemoryIssueStat;-><init>(JLjava/lang/String;DLjava/lang/String;Ljava/lang/String;ZILkotlin/f/b/j;)V
check-cast v1, Lsg/bigo/apm/a/d;
invoke-static {v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->a(Lsg/bigo/apm/a/d;)V
.line 3088
sget-object v1, Lsg/bigo/apm/plugins/memoryinfo/hprof/b;->a:Lsg/bigo/apm/plugins/memoryinfo/hprof/c;
new-instance v1, Lsg/bigo/apm/plugins/memoryinfo/hprof/b$a;
invoke-direct {v1, v10, v11, v0}, Lsg/bigo/apm/plugins/memoryinfo/hprof/b$a;-><init>(JLjava/lang/String;)V
check-cast v1, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;
const-string v0, "callback"
invoke-static {v1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 7047
:try_start_154
invoke-static {v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;->a(Lsg/bigo/apm/plugins/memoryinfo/hprof/a;)Z
move-result v0
if-eqz v0, :cond_1d4
.line 7051
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;->d()Ljava/lang/String;
move-result-object v0
.line 7052
move-object v2, v0
check-cast v2, Ljava/lang/CharSequence;
const/4 v3, 0x0
if-eqz v2, :cond_16d
invoke-interface {v2}, Ljava/lang/CharSequence;->length()I
move-result v2
if-nez v2, :cond_16b
goto :goto_16d
:cond_16b
const/4 v2, 0x0
goto :goto_16e
:cond_16d
:goto_16d
const/4 v2, 0x1
:goto_16e
if-eqz v2, :cond_175
const/4 v0, 0x4
.line 7053
invoke-interface {v1, v0}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a(I)V
return-void
.line 7057
:cond_175
new-instance v2, Ljava/io/File;
invoke-direct {v2, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 7058
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v6
if-eqz v6, :cond_193
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v6
cmp-long v10, v6, v8
if-gtz v10, :cond_18e
invoke-virtual {v2}, Ljava/io/File;->delete()Z
move-result v6
if-nez v6, :cond_193
:cond_18e
const/4 v0, 0x5
.line 7059
invoke-interface {v1, v0}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a(I)V
return-void
.line 7063
:cond_193
sget-object v6, Lleakcanary/KeyedWeakReference;->Companion:Lleakcanary/KeyedWeakReference$Companion;
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v10
invoke-virtual {v6, v10, v11}, Lleakcanary/KeyedWeakReference$Companion;->setHeapDumpUptimeMillis(J)V
.line 7064
invoke-interface {v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a()V
.line 7154
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v6
.line 7067
invoke-static {v0}, Landroid/os/Debug;->dumpHprofData(Ljava/lang/String;)V
.line 7156
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
sub-long/2addr v10, v6
.line 7070
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v6
cmp-long v0, v6, v8
if-nez v0, :cond_1ba
.line 7071
invoke-virtual {v2}, Ljava/io/File;->delete()Z
const/4 v0, 0x6
.line 7072
invoke-interface {v1, v0}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a(I)V
.line 7075
:cond_1ba
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;
invoke-static {v3}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a(I)V
.line 7076
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;
invoke-static {v3}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->b(I)V
.line 7077
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;
.line 8117
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
.line 7077
invoke-static {v2, v3}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a(J)V
.line 7078
invoke-interface {v1, v10, v11}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a(J)V
:try_end_1d0
.catchall {:try_start_154 .. :try_end_1d0} :catchall_1d1
return-void
.line 7080
:catchall_1d1
invoke-interface {v1, v5}, Lsg/bigo/apm/plugins/memoryinfo/hprof/a;->a(I)V
:cond_1d4
:goto_1d4
return-void
.end method
.method public final a(Lsg/bigo/apm/plugins/memoryinfo/b/d;)V
.registers 10
const-string v0, "memoryInfo"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 77
iget-object v1, p0, Lsg/bigo/apm/plugins/memoryinfo/b$b;->a:Lsg/bigo/apm/plugins/memoryinfo/b;
invoke-static {v1}, Lsg/bigo/apm/plugins/memoryinfo/b;->a(Lsg/bigo/apm/plugins/memoryinfo/b;)Lsg/bigo/apm/plugins/memoryinfo/c;
move-result-object v1
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 9060
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v2
.line 9039
iget-wide v4, v1, Lsg/bigo/apm/plugins/memoryinfo/c;->b:J
sub-long v4, v2, v4
sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/a/a;->a:Lsg/bigo/apm/plugins/memoryinfo/a/a;
invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/a/a;->h()J
move-result-wide v6
cmp-long v0, v4, v6
if-ltz v0, :cond_38
.line 9042
iput-wide v2, v1, Lsg/bigo/apm/plugins/memoryinfo/c;->b:J
.line 9044
new-instance v0, Lsg/bigo/apm/plugins/memoryinfo/b/j;
invoke-direct {v0, p1}, Lsg/bigo/apm/plugins/memoryinfo/b/j;-><init>(Lsg/bigo/apm/plugins/memoryinfo/b/d;)V
check-cast v0, Lsg/bigo/apm/a/d;
.line 9061
sget-object p1, Lsg/bigo/apm/a;->d:Lsg/bigo/apm/a$b;
invoke-static {}, Lsg/bigo/apm/a$b;->a()Lsg/bigo/apm/a;
move-result-object p1
.line 10019
iget-object p1, p1, Lsg/bigo/apm/a;->c:Lsg/bigo/apm/c/b;
.line 11014
iget-object v1, v1, Lsg/bigo/apm/plugins/memoryinfo/c;->c:Lsg/bigo/apm/plugins/memoryinfo/b;
.line 9061
check-cast v1, Lsg/bigo/apm/a/a;
invoke-virtual {p1, v1, v0}, Lsg/bigo/apm/c/b;->a(Lsg/bigo/apm/a/a;Lsg/bigo/apm/a/d;)V
:cond_38
return-void
.end method
.method public final a(Lsg/bigo/apm/plugins/memoryinfo/b/g;)V
.registers 4
const-string v0, "info"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 81
iget-object v1, p0, Lsg/bigo/apm/plugins/memoryinfo/b$b;->a:Lsg/bigo/apm/plugins/memoryinfo/b;
invoke-static {v1}, Lsg/bigo/apm/plugins/memoryinfo/b;->a(Lsg/bigo/apm/plugins/memoryinfo/b;)Lsg/bigo/apm/plugins/memoryinfo/c;
move-result-object v1
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 11048
new-instance v0, Lsg/bigo/apm/plugins/memoryinfo/b/h;
invoke-direct {v0, p1}, Lsg/bigo/apm/plugins/memoryinfo/b/h;-><init>(Lsg/bigo/apm/plugins/memoryinfo/b/g;)V
check-cast v0, Lsg/bigo/apm/a/d;
.line 11063
sget-object p1, Lsg/bigo/apm/a;->d:Lsg/bigo/apm/a$b;
invoke-static {}, Lsg/bigo/apm/a$b;->a()Lsg/bigo/apm/a;
move-result-object p1
.line 12019
iget-object p1, p1, Lsg/bigo/apm/a;->c:Lsg/bigo/apm/c/b;
.line 13014
iget-object v1, v1, Lsg/bigo/apm/plugins/memoryinfo/c;->c:Lsg/bigo/apm/plugins/memoryinfo/b;
.line 11063
check-cast v1, Lsg/bigo/apm/a/a;
invoke-virtual {p1, v1, v0}, Lsg/bigo/apm/c/b;->a(Lsg/bigo/apm/a/a;Lsg/bigo/apm/a/d;)V
return-void
.end method