HeapAnalyzeService.smali

.class public final Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;
.super Landroidx/core/app/JobIntentService;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$a;
    }
.end annotation


# static fields
.field public static final a:Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$a;


# instance fields
.field private b:J

.field private c:Ljava/lang/Thread$UncaughtExceptionHandler;

.field private d:Z


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

    new-instance v0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$a;

    const/4 v1, 0x0

    invoke-direct {v0, v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$a;-><init>(Lkotlin/f/b/j;)V

    sput-object v0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a:Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$a;

    return-void
.end method

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

    .line 35
    invoke-direct {p0}, Landroidx/core/app/JobIntentService;-><init>()V

    return-void
.end method

.method private final a(Ljava/io/File;I)Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;
    .registers 15

    const-string v0, "analyze_time"

    move v8, p2

    :goto_3
    const/4 p2, 0x2

    const-string v1, "HeapAnalyzeService"

    if-le v8, p2, :cond_2f

    const-string p2, "all analyze strategy failed"

    .line 114
    invoke-static {v1, p2}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 116
    sget-object p2, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->c()J

    move-result-wide v1

    .line 117
    invoke-virtual {p1}, Ljava/io/File;->length()J

    move-result-wide v3

    .line 321
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide p1

    .line 118
    iget-wide v5, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->b:J

    sub-long v5, p1, v5

    .line 115
    new-instance p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;

    const/4 v8, 0x0

    const/4 v9, 0x0

    const/16 v10, 0x30

    const/4 v11, 0x0

    const-string v7, "no analyze strategy"

    move-object v0, p1

    invoke-direct/range {v0 .. v11}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;-><init>(JJJLjava/lang/String;Ljava/lang/String;Ljava/lang/String;ILkotlin/f/b/j;)V

    check-cast p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;

    return-object p1

    .line 121
    :cond_2f
    sget-object p2, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {v8}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->b(I)V

    .line 122
    invoke-static {v8}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p2

    const-string v2, "analyzeHeap start\uff1a"

    invoke-virtual {v2, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    invoke-static {v1, p2}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 322
    :try_start_41
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v2

    .line 127
    sget-object p2, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    invoke-static {v8}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p2

    invoke-static {p2}, Lsg/bigo/apm/hprof/e;->b(Ljava/lang/String;)V

    .line 128
    sget-object p2, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    const-string p2, "analyze_begin"

    invoke-static {p2}, Lsg/bigo/apm/hprof/e;->a(Ljava/lang/String;)V
    :try_end_55
    .catchall {:try_start_41 .. :try_end_55} :catchall_c1

    .line 130
    :try_start_55
    sget-object p2, Lsg/bigo/apm/hprof/a;->a:Lsg/bigo/apm/hprof/a$a;

    invoke-static {}, Lsg/bigo/apm/hprof/a$a;->a()Lsg/bigo/apm/hprof/a;

    move-result-object p2

    invoke-interface {p2, p1, v8}, Lsg/bigo/apm/hprof/a;->analyze(Ljava/io/File;I)Lsg/bigo/apm/hprof/stat/HeapComponents;

    move-result-object v9
    :try_end_5f
    .catchall {:try_start_55 .. :try_end_5f} :catchall_b1

    .line 132
    :try_start_5f
    sget-object p2, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    .line 323
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v4

    sub-long/2addr v4, v2

    .line 132
    invoke-static {v4, v5}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object p2

    invoke-static {v0, p2}, Lsg/bigo/apm/hprof/e;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_6d
    .catchall {:try_start_5f .. :try_end_6d} :catchall_c1

    if-nez v9, :cond_96

    const-string p2, "heapComponents is null"

    .line 145
    invoke-static {v1, p2}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 147
    sget-object p2, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->c()J

    move-result-wide v1

    .line 148
    invoke-virtual {p1}, Ljava/io/File;->length()J

    move-result-wide v3

    .line 325
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide p1

    .line 149
    iget-wide v5, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->b:J

    sub-long v5, p1, v5

    .line 146
    new-instance p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;

    const/4 v8, 0x0

    const/4 v9, 0x0

    const/16 v10, 0x30

    const/4 v11, 0x0

    const-string v7, "heapComponents is null"

    move-object v0, p1

    invoke-direct/range {v0 .. v11}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;-><init>(JJJLjava/lang/String;Ljava/lang/String;Ljava/lang/String;ILkotlin/f/b/j;)V

    check-cast p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;

    return-object p1

    .line 153
    :cond_96
    sget-object p2, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->c()J

    move-result-wide v2

    .line 154
    invoke-virtual {p1}, Ljava/io/File;->length()J

    move-result-wide v4

    .line 326
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide p1

    .line 155
    iget-wide v0, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->b:J

    sub-long v6, p1, v0

    .line 152
    new-instance p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisSuccess;

    move-object v1, p1

    invoke-direct/range {v1 .. v9}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisSuccess;-><init>(JJJILsg/bigo/apm/hprof/stat/HeapComponents;)V

    check-cast p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;

    return-object p1

    :catchall_b1
    move-exception p2

    .line 132
    :try_start_b2
    sget-object v4, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    .line 324
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v4

    sub-long/2addr v4, v2

    .line 132
    invoke-static {v4, v5}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object v2

    invoke-static {v0, v2}, Lsg/bigo/apm/hprof/e;->a(Ljava/lang/String;Ljava/lang/String;)V

    throw p2
    :try_end_c1
    .catchall {:try_start_b2 .. :try_end_c1} :catchall_c1

    :catchall_c1
    move-exception p2

    .line 135
    invoke-static {p2}, Lsg/bigo/apm/plugins/memoryinfo/c/b;->a(Ljava/lang/Throwable;)Ljava/lang/OutOfMemoryError;

    move-result-object v2

    if-eqz v2, :cond_142

    .line 136
    invoke-static {v8}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p2

    const-string v2, "analyzeHeap failed for oom: "

    invoke-virtual {v2, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    invoke-static {v1, p2}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 2182
    new-instance p2, Ljava/util/concurrent/CountDownLatch;

    const/4 v2, 0x1

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

    .line 2183
    new-instance v2, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$c;

    invoke-direct {v2, p2}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$c;-><init>(Ljava/util/concurrent/CountDownLatch;)V

    check-cast v2, Ljava/lang/Runnable;

    .line 2187
    sget-object v3, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    const-string v3, "before_gc"

    invoke-static {v3}, Lsg/bigo/apm/hprof/e;->a(Ljava/lang/String;)V

    .line 2189
    :try_start_e9
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "java mem before gc: "

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

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

    move-result-object v4

    invoke-virtual {v4}, Ljava/lang/Runtime;->totalMemory()J

    move-result-wide v5

    invoke-virtual {v4}, Ljava/lang/Runtime;->freeMemory()J

    move-result-wide v9

    sub-long/2addr v5, v9

    invoke-virtual {v3, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v3

    invoke-static {v1, v3}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 2190
    invoke-static {v2}, Lsg/bigo/apm/plugins/a/a;->a(Ljava/lang/Runnable;)V

    .line 2191
    sget-object v3, 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

    const-wide/16 v3, 0x1e

    .line 2192
    sget-object v5, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-virtual {p2, v3, v4, v5}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z

    .line 2193
    sget-object p2, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    const-string p2, "after_gc"

    invoke-static {p2}, Lsg/bigo/apm/hprof/e;->a(Ljava/lang/String;)V

    .line 2194
    new-instance p2, Ljava/lang/StringBuilder;

    const-string v3, "java mem after gc: "

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

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

    move-result-object v3

    invoke-virtual {v3}, Ljava/lang/Runtime;->totalMemory()J

    move-result-wide v4

    invoke-virtual {v3}, Ljava/lang/Runtime;->freeMemory()J

    move-result-wide v6

    sub-long/2addr v4, v6

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

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

    move-result-object p2

    invoke-static {v1, p2}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_13b
    .catchall {:try_start_e9 .. :try_end_13b} :catchall_13b

    .line 2197
    :catchall_13b
    invoke-static {v2}, Lsg/bigo/apm/plugins/a/a;->b(Ljava/lang/Runnable;)V

    add-int/lit8 v8, v8, 0x1

    goto/16 :goto_3

    .line 141
    :cond_142
    goto :goto_144

    :goto_143
    throw p2

    :goto_144
    goto :goto_143
.end method

.method private static a()V
    .registers 2

    .line 107
    sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    const/4 v0, 0x0

    invoke-static {v0}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a(I)V

    .line 108
    sget-object v1, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {v0}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->b(I)V

    .line 109
    sget-object v0, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    const-wide/16 v0, 0x0

    invoke-static {v0, v1}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->b(J)V

    return-void
.end method

.method private final a(Ljava/io/File;Ljava/lang/String;Ljava/lang/Throwable;)V
    .registers 15

    const-string v0, ""

    if-eqz p3, :cond_13

    .line 165
    invoke-virtual {p3}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;

    move-result-object p3

    .line 166
    invoke-static {p3}, Lsg/bigo/apm/b/k;->a([Ljava/lang/StackTraceElement;)Ljava/lang/String;

    move-result-object v0

    .line 167
    invoke-static {p3}, Lsg/bigo/apm/b/k;->b([Ljava/lang/StackTraceElement;)Ljava/lang/String;

    move-result-object p3

    move-object v10, p3

    move-object v9, v0

    goto :goto_15

    :cond_13
    move-object v9, v0

    move-object v10, v9

    .line 171
    :goto_15
    sget-object p3, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->c()J

    move-result-wide v2

    .line 172
    invoke-virtual {p1}, Ljava/io/File;->length()J

    move-result-wide v4

    .line 327
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v0

    .line 173
    iget-wide v6, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->b:J

    sub-long v6, v0, v6

    .line 170
    new-instance p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;

    move-object v1, p1

    move-object v8, p2

    invoke-direct/range {v1 .. v10}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;-><init>(JJJLjava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    check-cast p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;

    .line 169
    invoke-direct {p0, p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;)V

    return-void
.end method

.method private final a(Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;)V
    .registers 8

    .line 202
    invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "sendAnalysis: "

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

    move-result-object v0

    const-string v1, "HeapAnalyzeService"

    invoke-static {v1, v0}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 328
    sget-object v0, Lkotlin/w;->a:Lkotlin/w;

    .line 337
    :try_start_11
    move-object v0, p0

    check-cast v0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;

    .line 204
    invoke-virtual {p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;->getExtras()Ljava/util/Map;

    move-result-object v1

    const-string v2, "analyze_count"

    sget-object v3, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a()I

    move-result v3

    invoke-static {v3}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v3

    invoke-interface {v1, v2, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    .line 205
    invoke-virtual {p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;->getExtras()Ljava/util/Map;

    move-result-object v1

    sget-object v2, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    invoke-static {}, Lsg/bigo/apm/hprof/e;->a()Ljava/util/Map;

    move-result-object v2

    invoke-interface {v1, v2}, Ljava/util/Map;->putAll(Ljava/util/Map;)V

    .line 206
    sget-object v1, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    invoke-static {}, Lsg/bigo/apm/hprof/e;->b()V

    .line 208
    instance-of v1, p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisSuccess;
    :try_end_3b
    .catchall {:try_start_11 .. :try_end_3b} :catchall_c1

    const-string v2, "key_analysis_result"

    const-string v3, "sg.bigo.apm.hprof.action.HEAP_ANALYSIS"

    if-eqz v1, :cond_9a

    .line 210
    :try_start_41
    new-instance v1, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;

    invoke-direct {v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;-><init>()V

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/c;->c()Ljava/io/File;

    move-result-object v1

    if-nez v1, :cond_4d

    return-void

    .line 211
    :cond_4d
    invoke-virtual {v1}, Ljava/io/File;->exists()Z

    move-result v4

    if-eqz v4, :cond_56

    .line 212
    invoke-virtual {v1}, Ljava/io/File;->delete()Z

    .line 214
    :cond_56
    new-instance v4, Ljava/io/ObjectOutputStream;

    new-instance v5, Ljava/io/FileOutputStream;

    invoke-direct {v5, v1}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V

    check-cast v5, Ljava/io/OutputStream;

    invoke-direct {v4, v5}, Ljava/io/ObjectOutputStream;-><init>(Ljava/io/OutputStream;)V

    check-cast v4, Ljava/io/Closeable;
    :try_end_64
    .catchall {:try_start_41 .. :try_end_64} :catchall_c1

    :try_start_64
    move-object v5, v4

    check-cast v5, Ljava/io/ObjectOutputStream;

    .line 215
    invoke-virtual {v5, p1}, Ljava/io/ObjectOutputStream;->writeObject(Ljava/lang/Object;)V

    .line 216
    sget-object p1, Lkotlin/w;->a:Lkotlin/w;
    :try_end_6c
    .catchall {:try_start_64 .. :try_end_6c} :catchall_93

    const/4 p1, 0x0

    .line 214
    :try_start_6d
    invoke-static {v4, p1}, Lkotlin/io/b;->a(Ljava/io/Closeable;Ljava/lang/Throwable;)V

    .line 217
    new-instance p1, Landroid/content/Intent;

    invoke-direct {p1, v3}, Landroid/content/Intent;-><init>(Ljava/lang/String;)V

    .line 218
    new-instance v3, Landroid/content/ComponentName;

    move-object v4, p0

    check-cast v4, Landroid/content/Context;

    const-class v5, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeReceiver;

    invoke-direct {v3, v4, v5}, Landroid/content/ComponentName;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    invoke-virtual {p1, v3}, Landroid/content/Intent;->setComponent(Landroid/content/ComponentName;)Landroid/content/Intent;

    const/4 v3, 0x1

    .line 219
    invoke-virtual {p1, v2, v3}, Landroid/content/Intent;->putExtra(Ljava/lang/String;I)Landroid/content/Intent;

    const-string v2, "key_heap_analysis_file_path"

    .line 220
    invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {p1, v2, v1}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;

    .line 217
    invoke-virtual {v0, p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->sendBroadcast(Landroid/content/Intent;)V
    :try_end_92
    .catchall {:try_start_6d .. :try_end_92} :catchall_c1

    goto :goto_be

    :catchall_93
    move-exception p1

    .line 214
    :try_start_94
    throw p1
    :try_end_95
    .catchall {:try_start_94 .. :try_end_95} :catchall_95

    :catchall_95
    move-exception v0

    :try_start_96
    invoke-static {v4, p1}, Lkotlin/io/b;->a(Ljava/io/Closeable;Ljava/lang/Throwable;)V

    throw v0

    .line 224
    :cond_9a
    instance-of v1, p1, Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysisFailure;

    if-eqz v1, :cond_be

    .line 225
    new-instance v1, Landroid/content/Intent;

    invoke-direct {v1, v3}, Landroid/content/Intent;-><init>(Ljava/lang/String;)V

    .line 226
    new-instance v3, Landroid/content/ComponentName;

    move-object v4, p0

    check-cast v4, Landroid/content/Context;

    const-class v5, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeReceiver;

    invoke-direct {v3, v4, v5}, Landroid/content/ComponentName;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    invoke-virtual {v1, v3}, Landroid/content/Intent;->setComponent(Landroid/content/ComponentName;)Landroid/content/Intent;

    const/4 v3, 0x2

    .line 227
    invoke-virtual {v1, v2, v3}, Landroid/content/Intent;->putExtra(Ljava/lang/String;I)Landroid/content/Intent;

    const-string v2, "key_heap_analysis_failed"

    .line 228
    check-cast p1, Ljava/io/Serializable;

    invoke-virtual {v1, v2, p1}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/io/Serializable;)Landroid/content/Intent;

    .line 225
    invoke-virtual {v0, v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->sendBroadcast(Landroid/content/Intent;)V

    .line 232
    :cond_be
    :goto_be
    sget-object p1, Lkotlin/w;->a:Lkotlin/w;
    :try_end_c0
    .catchall {:try_start_96 .. :try_end_c0} :catchall_c1

    return-void

    .line 339
    :catchall_c1
    invoke-static {}, Lsg/bigo/common/a;->e()Z

    return-void
.end method

.method private final a(Z)V
    .registers 3

    .line 92
    iput-boolean p1, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->d:Z

    if-eqz p1, :cond_18

    .line 93
    iget-object p1, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->c:Ljava/lang/Thread$UncaughtExceptionHandler;

    if-nez p1, :cond_18

    .line 94
    invoke-static {}, Ljava/lang/Thread;->getDefaultUncaughtExceptionHandler()Ljava/lang/Thread$UncaughtExceptionHandler;

    move-result-object p1

    .line 95
    new-instance v0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$b;

    invoke-direct {v0, p0, p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService$b;-><init>(Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;Ljava/lang/Thread$UncaughtExceptionHandler;)V

    check-cast v0, Ljava/lang/Thread$UncaughtExceptionHandler;

    iput-object v0, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->c:Ljava/lang/Thread$UncaughtExceptionHandler;

    .line 102
    invoke-static {v0}, Ljava/lang/Thread;->setDefaultUncaughtExceptionHandler(Ljava/lang/Thread$UncaughtExceptionHandler;)V

    :cond_18
    return-void
.end method

.method public static final synthetic a(Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;)Z
    .registers 1

    .line 35
    iget-boolean p0, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->d:Z

    return p0
.end method


# virtual methods
.method public final onHandleWork(Landroid/content/Intent;)V
    .registers 9

    const-string v0, "HeapAnalyzeService"

    const-string v1, "intent"

    invoke-static {p1, v1}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V

    .line 320
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v1

    iput-wide v1, p0, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->b:J

    .line 43
    sget-object v1, Lsg/bigo/apm/hprof/e;->a:Lsg/bigo/apm/hprof/e;

    invoke-static {}, Lsg/bigo/apm/hprof/e;->b()V

    const-string v1, "key_hprof_path"

    .line 44
    invoke-virtual {p1, v1}, Landroid/content/Intent;->getStringExtra(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    if-nez v1, :cond_1b

    return-void

    .line 45
    :cond_1b
    new-instance v2, Ljava/io/File;

    invoke-direct {v2, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 46
    invoke-virtual {v2}, Ljava/io/File;->exists()Z

    move-result v1

    if-eqz v1, :cond_ee

    invoke-virtual {v2}, Ljava/io/File;->length()J

    move-result-wide v3

    const-wide/16 v5, 0x0

    cmp-long v1, v3, v5

    if-nez v1, :cond_32

    goto/16 :goto_ee

    :cond_32
    const/4 v1, 0x0

    const-string v3, "key_clear_hprof"

    .line 49
    invoke-virtual {p1, v3, v1}, Landroid/content/Intent;->getBooleanExtra(Ljava/lang/String;Z)Z

    move-result p1

    const/4 v3, 0x0

    if-nez p1, :cond_e3

    .line 1060
    sget-object p1, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a()I

    move-result p1

    .line 1061
    sget-object v4, Lsg/bigo/apm/hprof/c;->a:Lsg/bigo/apm/hprof/c;

    invoke-static {}, Lsg/bigo/apm/hprof/c;->b()I

    move-result v4

    mul-int/lit8 v4, v4, 0x3

    if-le p1, v4, :cond_58

    const-string p1, "exceed max analyze count"

    .line 1161
    invoke-direct {p0, v2, p1, v3}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Ljava/io/File;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 1063
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    .line 1064
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a()V

    return-void

    .line 1067
    :cond_58
    sget-object v4, Lsg/bigo/apm/hprof/c;->a:Lsg/bigo/apm/hprof/c;

    invoke-static {}, Lsg/bigo/apm/hprof/c;->b()I

    move-result v4

    div-int v4, p1, v4

    sget-object v5, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    .line 2031
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->f()Landroid/content/SharedPreferences;

    move-result-object v5

    const-string v6, "key_analyze_strategy"

    invoke-interface {v5, v6, v1}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I

    move-result v5

    .line 1067
    invoke-static {v4, v5}, Ljava/lang/Math;->max(II)I

    move-result v4

    .line 1068
    sget-object v5, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a:Lsg/bigo/apm/plugins/memoryinfo/c/d;

    const/4 v5, 0x1

    add-int/2addr p1, v5

    sget-object v6, Lsg/bigo/apm/hprof/c;->a:Lsg/bigo/apm/hprof/c;

    invoke-static {}, Lsg/bigo/apm/hprof/c;->b()I

    move-result v6

    mul-int v6, v6, v4

    invoke-static {p1, v6}, Ljava/lang/Math;->max(II)I

    move-result p1

    invoke-static {p1}, Lsg/bigo/apm/plugins/memoryinfo/c/d;->a(I)V

    .line 1071
    :try_start_83
    invoke-direct {p0, v5}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Z)V

    .line 1072
    invoke-direct {p0, v2, v4}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Ljava/io/File;I)Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;

    move-result-object v3

    const-string p1, "analyze finish"

    .line 1073
    invoke-static {v0, p1}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_8f
    .catchall {:try_start_83 .. :try_end_8f} :catchall_9c

    .line 1082
    invoke-direct {p0, v3}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;)V

    .line 1084
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a()V

    .line 1085
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    .line 1086
    invoke-direct {p0, v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Z)V

    return-void

    :catchall_9c
    move-exception p1

    .line 1075
    :try_start_9d
    new-instance v4, Ljava/lang/StringBuilder;

    const-string v5, "analyze failed: "

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

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

    move-result-object v5

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

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

    move-result-object v4

    invoke-static {v0, v4}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 1076
    invoke-static {}, Lsg/bigo/common/a;->e()Z

    move-result v0

    if-eqz v0, :cond_d2

    .line 1079
    invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object v0

    if-nez v0, :cond_c0

    const-string v0, ""

    :cond_c0
    invoke-direct {p0, v2, v0, p1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Ljava/io/File;Ljava/lang/String;Ljava/lang/Throwable;)V
    :try_end_c3
    .catchall {:try_start_9d .. :try_end_c3} :catchall_d3

    if-eqz v3, :cond_c8

    .line 1082
    invoke-direct {p0, v3}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;)V

    .line 1084
    :cond_c8
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a()V

    .line 1085
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    .line 1086
    invoke-direct {p0, v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Z)V

    return-void

    .line 1077
    :cond_d2
    :try_start_d2
    throw p1
    :try_end_d3
    .catchall {:try_start_d2 .. :try_end_d3} :catchall_d3

    :catchall_d3
    move-exception p1

    if-eqz v3, :cond_d9

    .line 1082
    invoke-direct {p0, v3}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Lsg/bigo/apm/plugins/memoryinfo/hprof/stat/HeapAnalysis;)V

    .line 1084
    :cond_d9
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a()V

    .line 1085
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    .line 1086
    invoke-direct {p0, v1}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Z)V

    throw p1

    :cond_e3
    const-string p1, "analyze disable"

    .line 2161
    invoke-direct {p0, v2, p1, v3}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a(Ljava/io/File;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 53
    invoke-static {}, Lsg/bigo/apm/plugins/memoryinfo/hprof/HeapAnalyzeService;->a()V

    .line 54
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    :cond_ee
    :goto_ee
    return-void
.end method