ANRChecker.smali
.class public Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
.super Ljava/lang/Object;
.source "ANRChecker.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
}
.end annotation
# static fields
.field private static s_CheckTimeGap:J
.field private static s_DelayGap:J
.field static s_INS:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
# instance fields
.field private mAnrObsever:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
.field private mChekerHandler:Landroid/os/Handler;
.field private mMainHandler:Landroid/os/Handler;
.field private mMainThread:Ljava/lang/Thread;
.field private mRunChecker:Ljava/lang/Runnable;
.field private mRunMainChecker:Ljava/lang/Runnable;
.field private mThreader:Landroid/os/HandlerThread;
# direct methods
.method static constructor <clinit>()V
.registers 4
.prologue
.line 13
const/4 v0, 0x0
sput-object v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_INS:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
.line 56
const-wide/16 v0, 0x2710
sput-wide v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_CheckTimeGap:J
.line 57
sget-wide v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_CheckTimeGap:J
const-wide/16 v2, 0x1388
add-long/2addr v0, v2
sput-wide v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_DelayGap:J
return-void
.end method
.method constructor <init>()V
.registers 4
.prologue
const/4 v2, 0x0
.line 20
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 15
iput-object v2, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainThread:Ljava/lang/Thread;
.line 16
new-instance v0, Landroid/os/HandlerThread;
const-string v1, "anr_checker"
invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mThreader:Landroid/os/HandlerThread;
.line 17
iput-object v2, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
.line 18
iput-object v2, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainHandler:Landroid/os/Handler;
.line 19
iput-object v2, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mAnrObsever:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
.line 60
new-instance v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$1;
invoke-direct {v0, p0}, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$1;-><init>(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)V
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunMainChecker:Ljava/lang/Runnable;
.line 101
new-instance v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$2;
invoke-direct {v0, p0}, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$2;-><init>(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)V
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunChecker:Ljava/lang/Runnable;
.line 21
return-void
.end method
.method private PrintStack(Ljava/lang/Thread;[Ljava/lang/StackTraceElement;Ljava/lang/StringBuilder;)V
.registers 8
.prologue
.line 72
:try_start_0
const-string v0, "\t"
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 73
invoke-virtual {p1}, Ljava/lang/Thread;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 74
const-string v0, "\n"
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 75
if-eqz p2, :cond_31
array-length v0, p2
if-lez v0, :cond_31
.line 76
array-length v1, p2
const/4 v0, 0x0
:goto_18
if-ge v0, v1, :cond_31
aget-object v2, p2, v0
.line 77
const-string v3, "\t\t"
invoke-virtual {p3, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 78
invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {p3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 79
const-string v2, "\n"
invoke-virtual {p3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_2d
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_2d} :catch_30
.line 76
add-int/lit8 v0, v0, 0x1
goto :goto_18
.line 82
:catch_30
move-exception v0
.line 85
:cond_31
return-void
.end method
.method static synthetic access$000()J
.registers 2
.prologue
.line 11
sget-wide v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_CheckTimeGap:J
return-wide v0
.end method
.method static synthetic access$100(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)Landroid/os/Handler;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainHandler:Landroid/os/Handler;
return-object v0
.end method
.method static synthetic access$200(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)Ljava/lang/Runnable;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunChecker:Ljava/lang/Runnable;
return-object v0
.end method
.method static synthetic access$300(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)Landroid/os/Handler;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
return-object v0
.end method
.method static synthetic access$400()J
.registers 2
.prologue
.line 11
sget-wide v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_DelayGap:J
return-wide v0
.end method
.method static synthetic access$500(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)Ljava/lang/Thread;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainThread:Ljava/lang/Thread;
return-object v0
.end method
.method static synthetic access$600(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;Ljava/lang/Thread;[Ljava/lang/StackTraceElement;Ljava/lang/StringBuilder;)V
.registers 4
.prologue
.line 11
invoke-direct {p0, p1, p2, p3}, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->PrintStack(Ljava/lang/Thread;[Ljava/lang/StackTraceElement;Ljava/lang/StringBuilder;)V
return-void
.end method
.method static synthetic access$700(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;[Ljava/lang/StackTraceElement;)J
.registers 4
.prologue
.line 11
invoke-direct {p0, p1}, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->getANRkey([Ljava/lang/StackTraceElement;)J
move-result-wide v0
return-wide v0
.end method
.method static synthetic access$800(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;)Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
.registers 2
.prologue
.line 11
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mAnrObsever:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
return-object v0
.end method
.method private getANRkey([Ljava/lang/StackTraceElement;)J
.registers 6
.prologue
.line 88
const-wide/16 v0, 0x0
.line 90
if-eqz p1, :cond_1f
array-length v2, p1
const/4 v3, 0x1
if-le v2, v3, :cond_1f
.line 91
const/4 v0, 0x0
aget-object v0, p1, v0
.line 93
new-instance v1, Ljava/util/zip/CRC32;
invoke-direct {v1}, Ljava/util/zip/CRC32;-><init>()V
.line 94
invoke-virtual {v0}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->getBytes()[B
move-result-object v0
invoke-virtual {v1, v0}, Ljava/util/zip/CRC32;->update([B)V
.line 96
invoke-virtual {v1}, Ljava/util/zip/CRC32;->getValue()J
move-result-wide v0
.line 98
:cond_1f
return-wide v0
.end method
.method public static declared-synchronized getIns()Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
.registers 2
.prologue
.line 28
const-class v1, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
monitor-enter v1
:try_start_3
sget-object v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_INS:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
if-nez v0, :cond_e
.line 29
new-instance v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
invoke-direct {v0}, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;-><init>()V
sput-object v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_INS:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
.line 31
:cond_e
sget-object v0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_INS:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;
:try_end_10
.catchall {:try_start_3 .. :try_end_10} :catchall_12
monitor-exit v1
return-object v0
.line 28
:catchall_12
move-exception v0
monitor-exit v1
throw v0
.end method
# virtual methods
.method public declared-synchronized start(Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;)V
.registers 6
.prologue
.line 35
monitor-enter p0
:try_start_1
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
if-nez v0, :cond_5c
.line 37
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainThread:Ljava/lang/Thread;
.line 38
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v0
const-string v1, "main"
invoke-virtual {v0, v1}, Ljava/lang/String;->compareToIgnoreCase(Ljava/lang/String;)I
move-result v0
if-eqz v0, :cond_24
.line 39
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "Anr checker Start Must run on Main thread"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_21
.catchall {:try_start_1 .. :try_end_21} :catchall_21
.line 35
:catchall_21
move-exception v0
monitor-exit p0
throw v0
.line 42
:cond_24
:try_start_24
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mThreader:Landroid/os/HandlerThread;
invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V
.line 44
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
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainHandler:Landroid/os/Handler;
.line 45
new-instance v0, Landroid/os/Handler;
iget-object v1, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mThreader:Landroid/os/HandlerThread;
invoke-virtual {v1}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
iput-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
.line 48
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mMainHandler:Landroid/os/Handler;
iget-object v1, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunMainChecker:Ljava/lang/Runnable;
sget-wide v2, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_CheckTimeGap:J
invoke-virtual {v0, v1, v2, v3}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z
.line 49
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
iget-object v1, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunChecker:Ljava/lang/Runnable;
invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V
.line 50
iget-object v0, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mChekerHandler:Landroid/os/Handler;
iget-object v1, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mRunChecker:Ljava/lang/Runnable;
sget-wide v2, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->s_DelayGap:J
invoke-virtual {v0, v1, v2, v3}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z
.line 52
iput-object p1, p0, Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker;->mAnrObsever:Lcom/cleanmaster/hpsharelib/base/util/debug/ANRChecker$ANRListener;
:try_end_5c
.catchall {:try_start_24 .. :try_end_5c} :catchall_21
.line 54
:cond_5c
monitor-exit p0
return-void
.end method