CachedThreadScheduler.smali
.class public final Lrx/internal/schedulers/CachedThreadScheduler;
.super Lrx/Scheduler;
.source "CachedThreadScheduler.java"
# interfaces
.implements Lrx/internal/schedulers/SchedulerLifecycle;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;,
Lrx/internal/schedulers/CachedThreadScheduler$EventLoopWorker;,
Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
}
.end annotation
# static fields
.field private static final KEEP_ALIVE_TIME:J
.field private static final KEEP_ALIVE_UNIT:Ljava/util/concurrent/TimeUnit;
.field static final NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
.field static final SHUTDOWN_THREADWORKER:Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;
# instance fields
.field final pool:Ljava/util/concurrent/atomic/AtomicReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/atomic/AtomicReference<",
"Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;",
">;"
}
.end annotation
.end field
.field final threadFactory:Ljava/util/concurrent/ThreadFactory;
# direct methods
.method static constructor <clinit>()V
.registers 4
.line 1
sget-object v0, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
sput-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->KEEP_ALIVE_UNIT:Ljava/util/concurrent/TimeUnit;
.line 2
new-instance v0, Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;
sget-object v1, Lrx/internal/util/RxThreadFactory;->NONE:Ljava/util/concurrent/ThreadFactory;
invoke-direct {v0, v1}, Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;-><init>(Ljava/util/concurrent/ThreadFactory;)V
sput-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->SHUTDOWN_THREADWORKER:Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;
.line 3
sget-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->SHUTDOWN_THREADWORKER:Lrx/internal/schedulers/CachedThreadScheduler$ThreadWorker;
invoke-virtual {v0}, Lrx/internal/schedulers/NewThreadWorker;->unsubscribe()V
.line 4
new-instance v0, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
const/4 v1, 0x0
const-wide/16 v2, 0x0
invoke-direct {v0, v1, v2, v3, v1}, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;-><init>(Ljava/util/concurrent/ThreadFactory;JLjava/util/concurrent/TimeUnit;)V
sput-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
.line 5
sget-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
invoke-virtual {v0}, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;->shutdown()V
const-string v0, "rx.io-scheduler.keepalive"
const/16 v1, 0x3c
.line 6
invoke-static {v0, v1}, Ljava/lang/Integer;->getInteger(Ljava/lang/String;I)Ljava/lang/Integer;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
int-to-long v0, v0
sput-wide v0, Lrx/internal/schedulers/CachedThreadScheduler;->KEEP_ALIVE_TIME:J
return-void
.end method
.method public constructor <init>(Ljava/util/concurrent/ThreadFactory;)V
.registers 3
.line 1
invoke-direct {p0}, Lrx/Scheduler;-><init>()V
.line 2
iput-object p1, p0, Lrx/internal/schedulers/CachedThreadScheduler;->threadFactory:Ljava/util/concurrent/ThreadFactory;
.line 3
new-instance p1, Ljava/util/concurrent/atomic/AtomicReference;
sget-object v0, Lrx/internal/schedulers/CachedThreadScheduler;->NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
invoke-direct {p1, v0}, Ljava/util/concurrent/atomic/AtomicReference;-><init>(Ljava/lang/Object;)V
iput-object p1, p0, Lrx/internal/schedulers/CachedThreadScheduler;->pool:Ljava/util/concurrent/atomic/AtomicReference;
.line 4
invoke-virtual {p0}, Lrx/internal/schedulers/CachedThreadScheduler;->start()V
return-void
.end method
# virtual methods
.method public createWorker()Lrx/Scheduler$Worker;
.registers 3
.line 1
new-instance v0, Lrx/internal/schedulers/CachedThreadScheduler$EventLoopWorker;
iget-object v1, p0, Lrx/internal/schedulers/CachedThreadScheduler;->pool:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v1}, Ljava/util/concurrent/atomic/AtomicReference;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
invoke-direct {v0, v1}, Lrx/internal/schedulers/CachedThreadScheduler$EventLoopWorker;-><init>(Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;)V
return-object v0
.end method
.method public shutdown()V
.registers 4
.line 1
:cond_0
iget-object v0, p0, Lrx/internal/schedulers/CachedThreadScheduler;->pool:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicReference;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
.line 2
sget-object v1, Lrx/internal/schedulers/CachedThreadScheduler;->NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
if-ne v0, v1, :cond_d
return-void
.line 3
:cond_d
iget-object v2, p0, Lrx/internal/schedulers/CachedThreadScheduler;->pool:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v2, v0, v1}, Ljava/util/concurrent/atomic/AtomicReference;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_0
.line 4
invoke-virtual {v0}, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;->shutdown()V
return-void
.end method
.method public start()V
.registers 6
.line 1
new-instance v0, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
iget-object v1, p0, Lrx/internal/schedulers/CachedThreadScheduler;->threadFactory:Ljava/util/concurrent/ThreadFactory;
sget-wide v2, Lrx/internal/schedulers/CachedThreadScheduler;->KEEP_ALIVE_TIME:J
sget-object v4, Lrx/internal/schedulers/CachedThreadScheduler;->KEEP_ALIVE_UNIT:Ljava/util/concurrent/TimeUnit;
invoke-direct {v0, v1, v2, v3, v4}, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;-><init>(Ljava/util/concurrent/ThreadFactory;JLjava/util/concurrent/TimeUnit;)V
.line 2
iget-object v1, p0, Lrx/internal/schedulers/CachedThreadScheduler;->pool:Ljava/util/concurrent/atomic/AtomicReference;
sget-object v2, Lrx/internal/schedulers/CachedThreadScheduler;->NONE:Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;
invoke-virtual {v1, v2, v0}, Ljava/util/concurrent/atomic/AtomicReference;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_18
.line 3
invoke-virtual {v0}, Lrx/internal/schedulers/CachedThreadScheduler$CachedWorkerPool;->shutdown()V
:cond_18
return-void
.end method