DispatcherMonitor.smali
.class public Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;,
Lcom/imo/android/imoim/network/stat/DispatcherMonitor$MessageEvent;,
Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Holder;
}
.end annotation
# static fields
.field private static final DEFAULT_REPORT_INTERVAL:J = 0x493e0L
.field public static final NAMESPACE:Ljava/lang/String; = "dispatcher_stats"
.field private static final TAG:Ljava/lang/String; = "DispatcherMonitor"
.field private static final UNIT_MS:I = 0x32
.field private static final WHAT_RECV_MSG:I = 0x2
.field private static final WHAT_SEND_MSG:I = 0x1
.field private static final WHAT_TIMER:I = 0x3
# instance fields
.field private canLog:Z
.field private lastRecvAt:J
.field private lastSendAt:J
.field private mInterval:J
.field private recvQueue:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;",
">;"
}
.end annotation
.end field
.field private sendQueue:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;",
">;"
}
.end annotation
.end field
.field private timeAfterLastSendRecv:J
.field private worker:Landroid/os/Handler;
# direct methods
.method private constructor <init>()V
.registers 3
.line 58
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-wide/16 v0, 0x0
.line 35
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->timeAfterLastSendRecv:J
.line 37
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
.line 38
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
.line 40
new-instance v0, Ljava/util/LinkedList;
invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->sendQueue:Ljava/util/List;
.line 41
new-instance v0, Ljava/util/LinkedList;
invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->recvQueue:Ljava/util/List;
const/4 v0, 0x0
.line 45
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->canLog:Z
.line 59
iput-boolean v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->canLog:Z
return-void
.end method
.method synthetic constructor <init>(Lcom/imo/android/imoim/network/stat/DispatcherMonitor$1;)V
.registers 2
.line 25
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;-><init>()V
return-void
.end method
.method static synthetic access$200(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;)Ljava/util/List;
.registers 1
.line 25
iget-object p0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->sendQueue:Ljava/util/List;
return-object p0
.end method
.method static synthetic access$300(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;)Ljava/util/List;
.registers 1
.line 25
iget-object p0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->recvQueue:Ljava/util/List;
return-object p0
.end method
.method static synthetic access$400(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.registers 2
.line 25
invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getLastUnit(Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
move-result-object p0
return-object p0
.end method
.method static synthetic access$500(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.registers 2
.line 25
invoke-direct {p0, p1}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getNewUnit(Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
move-result-object p0
return-object p0
.end method
.method static synthetic access$600(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;)Landroid/os/Handler;
.registers 1
.line 25
iget-object p0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->worker:Landroid/os/Handler;
return-object p0
.end method
.method static synthetic access$700(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;)V
.registers 1
.line 25
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->doReport()V
return-void
.end method
.method static synthetic access$800(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;)J
.registers 3
.line 25
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->mInterval:J
return-wide v0
.end method
.method private doReport()V
.registers 22
move-object/from16 v0, p0
.line 114
iget-boolean v1, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->canLog:Z
if-nez v1, :cond_7
return-void
.line 116
:cond_7
iget-object v1, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->sendQueue:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
if-gtz v1, :cond_18
iget-object v1, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->recvQueue:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
if-gtz v1, :cond_18
return-void
.line 120
:cond_18
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
.line 130
iget-object v2, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->sendQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
const-wide/16 v6, 0x0
const-wide/16 v8, 0x0
const-wide/16 v10, 0x0
const/4 v12, 0x0
const-wide/16 v13, 0x0
:goto_2c
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v15
const-wide/16 v16, 0x1
if-eqz v15, :cond_50
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v15
check-cast v15, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.line 131
iget-wide v3, v15, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->costTime:J
add-long/2addr v8, v3
.line 132
iget v3, v15, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->count:I
int-to-long v3, v3
add-long/2addr v10, v3
add-long v6, v6, v16
.line 134
iget v3, v15, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->count:I
invoke-static {v12, v3}, Ljava/lang/Math;->max(II)I
move-result v12
.line 135
iget-wide v3, v15, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->costTime:J
invoke-static {v13, v14, v3, v4}, Ljava/lang/Math;->max(JJ)J
move-result-wide v13
goto :goto_2c
:cond_50
const-wide/16 v18, 0x0
cmp-long v2, v6, v18
if-lez v2, :cond_59
.line 138
div-long v2, v8, v6
goto :goto_5b
:cond_59
move-wide/from16 v2, v18
:goto_5b
cmp-long v4, v10, v18
if-lez v4, :cond_62
.line 141
div-long v4, v8, v10
goto :goto_64
:cond_62
move-wide/from16 v4, v18
:goto_64
cmp-long v20, v6, v18
if-lez v20, :cond_6c
long-to-float v15, v10
long-to-float v0, v6
div-float/2addr v15, v0
goto :goto_6d
:cond_6c
const/4 v15, 0x0
.line 147
:goto_6d
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v8, "send_total_cost_time"
invoke-interface {v1, v8, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 148
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "send_avg_unit_cost_time"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 149
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "send_total_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 150
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "send_avg_cost_time"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 151
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "send_unit_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 152
invoke-static {v15}, Ljava/lang/Float;->valueOf(F)Ljava/lang/Float;
move-result-object v0
const-string v2, "send_unit_avg_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 153
invoke-static {v12}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
const-string v2, "send_unit_max_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 154
invoke-static {v13, v14}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "send_unit_max_cost_time"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
move-object/from16 v0, p0
.line 156
iget-object v2, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->sendQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->clear()V
.line 166
iget-object v2, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->recvQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
const/4 v3, 0x0
const-wide/16 v4, 0x0
const-wide/16 v6, 0x0
const-wide/16 v8, 0x0
const-wide/16 v10, 0x0
:goto_cb
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v12
if-eqz v12, :cond_ed
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v12
check-cast v12, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.line 167
iget-wide v13, v12, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->costTime:J
add-long/2addr v6, v13
.line 168
iget v13, v12, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->count:I
int-to-long v13, v13
add-long/2addr v8, v13
add-long v4, v4, v16
.line 170
iget v13, v12, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->count:I
invoke-static {v3, v13}, Ljava/lang/Math;->max(II)I
move-result v3
.line 171
iget-wide v12, v12, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;->costTime:J
invoke-static {v10, v11, v12, v13}, Ljava/lang/Math;->max(JJ)J
move-result-wide v10
goto :goto_cb
:cond_ed
const-wide/16 v18, 0x0
cmp-long v2, v4, v18
if-lez v2, :cond_f6
.line 174
div-long v12, v6, v4
goto :goto_f8
:cond_f6
move-wide/from16 v12, v18
:goto_f8
cmp-long v2, v8, v18
if-lez v2, :cond_ff
.line 177
div-long v14, v6, v8
goto :goto_101
:cond_ff
move-wide/from16 v14, v18
:goto_101
cmp-long v2, v4, v18
if-lez v2, :cond_10a
long-to-float v2, v8
long-to-float v0, v4
div-float v0, v2, v0
goto :goto_10b
:cond_10a
const/4 v0, 0x0
.line 183
:goto_10b
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const-string v6, "recv_total_cost_time"
invoke-interface {v1, v6, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 184
invoke-static {v12, v13}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const-string v6, "recv_avg_unit_cost_time"
invoke-interface {v1, v6, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 185
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const-string v6, "recv_total_count"
invoke-interface {v1, v6, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 186
invoke-static {v14, v15}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const-string v6, "recv_avg_cost_time"
invoke-interface {v1, v6, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 187
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const-string v4, "recv_unit_count"
invoke-interface {v1, v4, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 188
invoke-static {v0}, Ljava/lang/Float;->valueOf(F)Ljava/lang/Float;
move-result-object v0
const-string v2, "recv_unit_avg_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 189
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
const-string v2, "recv_unit_max_count"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 190
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
const-string v2, "recv_unit_max_cost_time"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
move-object/from16 v0, p0
.line 192
iget-object v2, v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->recvQueue:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->clear()V
.line 197
sget-object v2, Lcom/imo/android/imoim/IMO;->O:Lcom/imo/android/imoim/managers/m;
const-string v3, "dispatcher_stats"
invoke-virtual {v2, v3}, Lcom/imo/android/imoim/managers/m;->a(Ljava/lang/String;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v2
invoke-virtual {v2, v1}, Lcom/imo/android/imoim/managers/m$a;->a(Ljava/util/Map;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v1
const/4 v2, 0x1
.line 1635
iput-boolean v2, v1, Lcom/imo/android/imoim/managers/m$a;->f:Z
.line 197
invoke-virtual {v1}, Lcom/imo/android/imoim/managers/m$a;->c()V
return-void
.end method
.method public static get()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
.registers 1
.line 55
# getter for: Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Holder;->instance:Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
invoke-static {}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Holder;->access$100()Lcom/imo/android/imoim/network/stat/DispatcherMonitor;
move-result-object v0
return-object v0
.end method
.method private getHandler()Landroid/os/Handler;
.registers 5
.line 63
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->worker:Landroid/os/Handler;
if-nez v0, :cond_25
.line 64
new-instance v0, Landroid/os/HandlerThread;
const-string v1, "dispatcher"
invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
.line 65
invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V
.line 66
new-instance v1, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$1;
invoke-virtual {v0}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
move-result-object v0
invoke-direct {v1, p0, v0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$1;-><init>(Lcom/imo/android/imoim/network/stat/DispatcherMonitor;Landroid/os/Looper;)V
iput-object v1, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->worker:Landroid/os/Handler;
.line 88
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getStatInterval()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->mInterval:J
.line 92
iget-object v2, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->worker:Landroid/os/Handler;
const/4 v3, 0x3
invoke-virtual {v2, v3, v0, v1}, Landroid/os/Handler;->sendEmptyMessageDelayed(IJ)Z
.line 94
:cond_25
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->worker:Landroid/os/Handler;
return-object v0
.end method
.method private getLastUnit(Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;",
">;)",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;"
}
.end annotation
.line 201
invoke-static {p1}, Lcom/imo/android/imoim/util/common/i;->a(Ljava/util/Collection;)Z
move-result v0
if-eqz v0, :cond_10
.line 202
new-instance v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;-><init>(Lcom/imo/android/imoim/network/stat/DispatcherMonitor$1;)V
.line 203
invoke-interface {p1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
return-object v0
.line 206
:cond_10
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v0
add-int/lit8 v0, v0, -0x1
invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
return-object p1
.end method
.method private getNewUnit(Ljava/util/List;)Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;",
">;)",
"Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;"
}
.end annotation
.line 210
new-instance v0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$Unit;-><init>(Lcom/imo/android/imoim/network/stat/DispatcherMonitor$1;)V
.line 211
invoke-interface {p1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
return-object v0
.end method
.method private getStatInterval()J
.registers 5
const-wide/32 v0, 0x493e0
.line 101
:try_start_3
sget-object v2, Lcom/imo/android/imoim/IMO;->Q:Lcom/imo/android/imoim/abtest/h;
const-string v3, "cc.proto.stat.interval"
invoke-virtual {v2, v3}, Lcom/imo/android/imoim/abtest/h;->a(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v2
if-eqz v2, :cond_18
.line 103
check-cast v2, Ljava/lang/String;
invoke-static {v2}, Ljava/lang/Long;->valueOf(Ljava/lang/String;)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
:try_end_17
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_17} :catch_18
goto :goto_19
:catch_18
:cond_18
move-wide v2, v0
.line 110
:goto_19
invoke-static {v2, v3, v0, v1}, Ljava/lang/Math;->max(JJ)J
move-result-wide v0
return-wide v0
.end method
# virtual methods
.method public addReceiveMessageEvent(J)V
.registers 7
.line 241
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->canLog:Z
if-nez v0, :cond_5
return-void
.line 244
:cond_5
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getHandler()Landroid/os/Handler;
move-result-object v0
const/4 v1, 0x2
invoke-static {v0, v1}, Landroid/os/Message;->obtain(Landroid/os/Handler;I)Landroid/os/Message;
move-result-object v0
.line 245
new-instance v1, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$MessageEvent;
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->timeAfterLastSendRecv:J
invoke-direct {v1, v2, v3, p1, p2}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$MessageEvent;-><init>(JJ)V
iput-object v1, v0, Landroid/os/Message;->obj:Ljava/lang/Object;
.line 246
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getHandler()Landroid/os/Handler;
move-result-object p1
invoke-virtual {p1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
.line 247
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide p1
iput-wide p1, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
return-void
.end method
.method public addSendMessageEvent(J)V
.registers 7
.line 224
iget-boolean v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->canLog:Z
if-nez v0, :cond_5
return-void
.line 226
:cond_5
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getHandler()Landroid/os/Handler;
move-result-object v0
const/4 v1, 0x1
invoke-static {v0, v1}, Landroid/os/Message;->obtain(Landroid/os/Handler;I)Landroid/os/Message;
move-result-object v0
.line 227
new-instance v1, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$MessageEvent;
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->timeAfterLastSendRecv:J
invoke-direct {v1, v2, v3, p1, p2}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor$MessageEvent;-><init>(JJ)V
iput-object v1, v0, Landroid/os/Message;->obj:Ljava/lang/Object;
.line 228
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->getHandler()Landroid/os/Handler;
move-result-object p1
invoke-virtual {p1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
.line 229
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide p1
iput-wide p1, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
return-void
.end method
.method public markAddRecvMessageStart()V
.registers 7
.line 233
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_e
.line 234
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
.line 236
:cond_e
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
sub-long/2addr v0, v2
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-wide v4, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
sub-long/2addr v2, v4
invoke-static {v0, v1, v2, v3}, Ljava/lang/Math;->min(JJ)J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->timeAfterLastSendRecv:J
.line 237
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
return-void
.end method
.method public markAddSendMessageStart()V
.registers 7
.line 216
iget-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_e
.line 217
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
.line 219
:cond_e
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iget-wide v2, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
sub-long/2addr v0, v2
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
iget-wide v4, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastRecvAt:J
sub-long/2addr v2, v4
invoke-static {v0, v1, v2, v3}, Ljava/lang/Math;->min(JJ)J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->timeAfterLastSendRecv:J
.line 220
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/DispatcherMonitor;->lastSendAt:J
return-void
.end method