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