ProtoQueenMonitor.smali
.class public Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;
}
.end annotation
# static fields
.field private static final CHECK_QUEEN_LOOP_GAP:J = 0x493e0L
.field private static final CHECK_QUEEN_START_GAP:J = 0x2710L
.field private static final SEND_STAT_CNT_LIMIT:I = 0xf
.field private static final TAG:Ljava/lang/String; = "ProtoQueenMonitor"
# instance fields
.field private lastSentSucTs:J
.field private lastSucProtoTsSortSet:Ljava/util/SortedSet;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/SortedSet<",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private loopCheckRunnable:Ljava/lang/Runnable;
.field private protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;
.field private reportCntFromEnterFg:I
.field private reportCntFromStart:I
.field private switchToFgTs:J
# direct methods
.method public constructor <init>(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;)V
.registers 4
.line 55
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-wide/16 v0, 0x0
.line 37
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J
.line 39
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J
const/4 v0, 0x0
.line 41
iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I
.line 42
iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I
.line 44
new-instance v0, Ljava/util/TreeSet;
invoke-direct {v0}, Ljava/util/TreeSet;-><init>()V
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
.line 123
new-instance v0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$1;
invoke-direct {v0, p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$1;-><init>(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)V
iput-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;
.line 56
iput-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;
return-void
.end method
.method static synthetic access$000(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)V
.registers 1
.line 29
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->snapshotProtoQueenStateAndReport()V
return-void
.end method
.method static synthetic access$100(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)Z
.registers 1
.line 29
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z
move-result p0
return p0
.end method
.method static synthetic access$200(Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;)Ljava/lang/Runnable;
.registers 1
.line 29
iget-object p0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;
return-object p0
.end method
.method private clearMoreThan5MinProtoForLastSucProtoTsSortSet()V
.registers 11
.line 89
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
.line 90
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
.line 91
iget-object v3, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
invoke-interface {v3}, Ljava/util/SortedSet;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_f
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_2c
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/Long;
.line 92
invoke-virtual {v4}, Ljava/lang/Long;->longValue()J
move-result-wide v5
sub-long v5, v0, v5
const-wide/32 v7, 0x493e0
cmp-long v9, v5, v7
if-lez v9, :cond_2c
.line 93
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_f
.line 98
:cond_2c
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
invoke-interface {v0, v2}, Ljava/util/SortedSet;->removeAll(Ljava/util/Collection;)Z
return-void
.end method
.method private needMonitor()Z
.registers 3
.line 61
sget-object v0, Lcom/imo/android/imoim/IMO;->Q:Lcom/imo/android/imoim/abtest/h;
const-string v1, "cc.protos.queen.monitor.disable"
invoke-virtual {v0, v1}, Lcom/imo/android/imoim/abtest/h;->a(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
const-string v1, "1"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x0
if-eqz v0, :cond_11
:cond_11
return v1
.end method
.method private snapshotProtoQueenStateAndReport()V
.registers 9
.line 136
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
.line 138
new-instance v1, Ljava/util/LinkedList;
iget-object v2, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->protoQueenEvn:Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;
invoke-interface {v2}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor$ProtoQueenEvn;->getProtoQueen()Ljava/util/Queue;
move-result-object v2
invoke-direct {v1, v2}, Ljava/util/LinkedList;-><init>(Ljava/util/Collection;)V
.line 140
invoke-virtual {v1}, Ljava/util/LinkedList;->size()I
move-result v2
invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v2
const-string v3, "size"
invoke-interface {v0, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 142
new-instance v2, Ljava/util/HashMap;
invoke-direct {v2}, Ljava/util/HashMap;-><init>()V
.line 143
invoke-virtual {v1}, Ljava/util/LinkedList;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_26
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v4
const/4 v5, 0x1
if-eqz v4, :cond_69
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
.line 144
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
iget-object v7, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object v7, v7, Lcom/imo/android/imoim/util/y;->c:Ljava/lang/String;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v7, "#"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->message:Lcom/imo/android/imoim/util/y;
iget-object v4, v4, Lcom/imo/android/imoim/util/y;->a:Ljava/lang/String;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 145
invoke-virtual {v2, v4}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v6
check-cast v6, Ljava/lang/Integer;
if-nez v6, :cond_5c
const/4 v6, 0x0
.line 147
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
.line 149
:cond_5c
invoke-virtual {v6}, Ljava/lang/Integer;->intValue()I
move-result v6
add-int/2addr v6, v5
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v5
.line 150
invoke-virtual {v2, v4, v5}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_26
.line 153
:cond_69
invoke-virtual {v2}, Ljava/util/HashMap;->size()I
move-result v3
if-lez v3, :cond_7d
.line 154
new-instance v3, Lorg/json/JSONObject;
invoke-direct {v3, v2}, Lorg/json/JSONObject;-><init>(Ljava/util/Map;)V
.line 155
invoke-virtual {v3}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object v2
const-string v3, "protocol_map"
invoke-interface {v0, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 159
:cond_7d
invoke-virtual {v1}, Ljava/util/LinkedList;->size()I
move-result v2
if-lez v2, :cond_ca
.line 160
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v6
sub-long/2addr v2, v6
.line 163
invoke-virtual {v1}, Ljava/util/LinkedList;->getFirst()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
if-eqz v4, :cond_ab
.line 165
iget-wide v6, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->lastSendTime:J
add-long/2addr v6, v2
invoke-static {v6, v7}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v6
const-string v7, "oldest_proto_ts"
invoke-interface {v0, v7, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 166
iget v4, v4, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v4
const-string v6, "oldest_proto_retry_cnt"
invoke-interface {v0, v6, v4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 169
:cond_ab
invoke-virtual {v1}, Ljava/util/LinkedList;->getLast()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;
if-eqz v1, :cond_ca
.line 171
iget-wide v6, v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->lastSendTime:J
add-long/2addr v6, v2
invoke-static {v6, v7}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v2
const-string v3, "latest_proto_ts"
invoke-interface {v0, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 172
iget v1, v1, Lcom/imo/android/imoim/network/Dispatcher4$OutgoingImoMessage;->numberTransmissions:I
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "latest_proto_retry_cnt"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 176
:cond_ca
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->clearMoreThan5MinProtoForLastSucProtoTsSortSet()V
.line 177
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J
invoke-static {v1, v2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v1
const-string v2, "last_proto_suc_ts"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 178
iget-object v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
invoke-interface {v1}, Ljava/util/SortedSet;->size()I
move-result v1
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "last_5_min_suc_proto_cnt"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 180
invoke-static {}, Lcom/imo/android/imoim/util/ei;->J()Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_ee
goto :goto_f0
:cond_ee
const-string v1, ""
:goto_f0
const-string v2, "net"
.line 181
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 182
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object v1
invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getTcpConnectState()I
move-result v1
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "tcp"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 183
invoke-static {}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->get()Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;
move-result-object v1
invoke-virtual {v1}, Lcom/imo/android/imoim/network/stat/connect/ConnectStatHelper;->getGCMConnectState()I
move-result v1
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "gcm"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 185
iget-wide v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J
invoke-static {v1, v2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v1
const-string v2, "switch_fg_ts"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 186
iget v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "report_cnt_from_start"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 187
iget v1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "report_cnt_from_enter_fg"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 192
sget-object v1, Lcom/imo/android/imoim/IMO;->O:Lcom/imo/android/imoim/managers/m;
const-string v2, "proto_queen_monitor"
invoke-virtual {v1, v2}, Lcom/imo/android/imoim/managers/m;->a(Ljava/lang/String;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/imo/android/imoim/managers/m$a;->a(Ljava/util/Map;)Lcom/imo/android/imoim/managers/m$a;
move-result-object v0
.line 1635
iput-boolean v5, v0, Lcom/imo/android/imoim/managers/m$a;->f:Z
.line 192
invoke-virtual {v0}, Lcom/imo/android/imoim/managers/m$a;->c()V
.line 195
iget-object v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
invoke-interface {v0}, Ljava/util/SortedSet;->clear()V
.line 196
iget v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I
add-int/2addr v0, v5
iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I
.line 197
iget v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I
add-int/2addr v0, v5
iput v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromStart:I
return-void
.end method
# virtual methods
.method public markProtoSentSuc()V
.registers 4
.line 78
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z
move-result v0
if-nez v0, :cond_7
return-void
.line 82
:cond_7
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSentSucTs:J
.line 84
iget-object v2, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->lastSucProtoTsSortSet:Ljava/util/SortedSet;
invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
invoke-interface {v2, v0}, Ljava/util/SortedSet;->add(Ljava/lang/Object;)Z
return-void
.end method
.method public switchToForegroundAndMonitor(Z)V
.registers 4
.line 108
invoke-direct {p0}, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->needMonitor()Z
move-result v0
if-nez v0, :cond_7
return-void
:cond_7
if-eqz p1, :cond_1a
.line 114
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->switchToFgTs:J
const/4 p1, 0x0
.line 115
iput p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->reportCntFromEnterFg:I
.line 117
iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;
const-wide/16 v0, 0x2710
invoke-static {p1, v0, v1}, Lcom/imo/android/imoim/util/ec;->a(Ljava/lang/Runnable;J)V
return-void
.line 119
:cond_1a
iget-object p1, p0, Lcom/imo/android/imoim/network/stat/ProtoQueenMonitor;->loopCheckRunnable:Ljava/lang/Runnable;
.line 1029
invoke-static {}, Lcom/imo/android/imoim/util/ec$a;->a()Landroid/os/Handler;
move-result-object v0
invoke-virtual {v0, p1}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V
return-void
.end method