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