AsyncStringPrinter$Worker.smali
.class Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;
.super Ljava/lang/Object;
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0xa
name = "Worker"
.end annotation
# instance fields
.field private mAsyncCount:I
.field private final mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
.field private mLogQueue:Ljava/util/concurrent/BlockingQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/BlockingQueue",
"<",
"Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;",
">;"
}
.end annotation
.end field
# direct methods
.method private constructor <init>()V
.registers 3
const/4 v1, 0x0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Ljava/util/concurrent/LinkedBlockingDeque;
invoke-direct {v0}, Ljava/util/concurrent/LinkedBlockingDeque;-><init>()V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;
new-instance v0, Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-direct {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
iput v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I
return-void
.end method
.method synthetic constructor <init>(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$1;)V
.registers 2
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;-><init>()V
return-void
.end method
.method static synthetic access$100(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;)V
.registers 1
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->tryStart()V
return-void
.end method
.method static synthetic access$200(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
.registers 3
invoke-direct {p0, p1, p2}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->enqueue(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
return-void
.end method
.method private enqueue(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
.registers 5
:try_start_0
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;
new-instance v1, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;
invoke-direct {v1, p1, p2}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;-><init>(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/BlockingQueue;->put(Ljava/lang/Object;)V
:try_end_a
.catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_a} :catch_b
:goto_a
return-void
:catch_b
move-exception v0
invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V
goto :goto_a
.end method
.method private tryStart()V
.registers 5
iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
monitor-enter v1
:try_start_3
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z
move-result v0
if-nez v0, :cond_3a
new-instance v0, Ljava/lang/Thread;
invoke-direct {v0, p0}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;)V
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/lang/Thread;->setPriority(I)V
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, "AsyncStringPrinter-"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I
add-int/lit8 v3, v3, 0x1
iput v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Thread;->start()V
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
:cond_3a
monitor-exit v1
return-void
:catchall_3c
move-exception v0
monitor-exit v1
:try_end_3e
.catchall {:try_start_3 .. :try_end_3e} :catchall_3c
throw v0
.end method
# virtual methods
.method public run()V
.registers 4
:goto_0
:try_start_0
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;
invoke-interface {v0}, Ljava/util/concurrent/BlockingQueue;->take()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;
if-eqz v0, :cond_1a
# getter for: Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->mPrinter:Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
invoke-static {v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->access$300(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;)Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
move-result-object v1
# getter for: Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->mLog:Ljava/lang/String;
invoke-static {v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->access$400(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;->doPrintln(Ljava/lang/String;)V
:try_end_15
.catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_15} :catch_16
goto :goto_0
:catch_16
move-exception v0
invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V
:cond_1a
iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
monitor-enter v1
:try_start_1d
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v2, 0x0
invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
monitor-exit v1
return-void
:catchall_25
move-exception v0
monitor-exit v1
:try_end_27
.catchall {:try_start_1d .. :try_end_27} :catchall_25
throw v0
.end method