當前位置: 首頁>>代碼示例>>Java>>正文


Java TcpContext類代碼示例

本文整理匯總了Java中org.telegram.mtproto.transport.TcpContext的典型用法代碼示例。如果您正苦於以下問題:Java TcpContext類的具體用法?Java TcpContext怎麽用?Java TcpContext使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TcpContext類屬於org.telegram.mtproto.transport包,在下文中一共展示了TcpContext類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: onChannelBroken

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
@Override
public void onChannelBroken(TcpContext context) {
    if (MTProto.this.isClosed) {
        return;
    }
    int contextId = context.getContextId();
    Logger.d(MTProto.this.TAG, "onChannelBroken (#" + contextId + ")");
    synchronized (MTProto.this.contexts) {
        MTProto.this.contexts.remove(context);
        if (!MTProto.this.connectedContexts.contains(contextId)) {
            if (MTProto.this.contextConnectionId.containsKey(contextId)) {
                MTProto.this.exponentalBackoff.onFailureNoWait();
                MTProto.this.connectionRate.onConnectionFailure(MTProto.this.contextConnectionId.get(contextId));
            }
        }
        MTProto.this.contexts.notifyAll();
    }
    MTProto.this.scheduller.onConnectionDies(context.getContextId());
    requestSchedule();
}
 
開發者ID:rubenlagus,項目名稱:TelegramApi,代碼行數:21,代碼來源:MTProto.java

示例2: onChannelBroken

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
@Override
public void onChannelBroken(TcpContext context) {
    if (isClosed) {
        return;
    }
    int contextId = context.getContextId();
    Logger.d(TAG, "onChannelBroken (#" + contextId + ")");
    synchronized (contexts) {
        contexts.remove(context);
        if (!connectedContexts.contains(contextId)) {
            if (contextConnectionId.containsKey(contextId)) {
                exponentalBackoff.onFailureNoWait();
                connectionRate.onConnectionFailure(contextConnectionId.get(contextId));
            }
        }
        contexts.notifyAll();
    }
    scheduller.onConnectionDies(context.getContextId());
    requestSchedule();
}
 
開發者ID:ardock,項目名稱:telegram-mt,代碼行數:21,代碼來源:MTProto.java

示例3: closeConnections

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
public void closeConnections() {
    synchronized (this.contexts) {
        for (TcpContext context : this.contexts) {
            context.suspendConnection(true);
            this.scheduller.onConnectionDies(context.getContextId());
        }
        this.contexts.clear();
        this.contexts.notifyAll();
    }
}
 
開發者ID:rubenlagus,項目名稱:TelegramApi,代碼行數:11,代碼來源:MTProto.java

示例4: internalSchedule

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
private void internalSchedule() {
    long time = System.nanoTime() / 1000000;
    if (time - this.lastPingTime > PING_INTERVAL_REQUEST) {
        this.lastPingTime = time;
        synchronized (this.contexts) {
            for (TcpContext context : this.contexts) {
                this.scheduller.postMessageDelayed(
                        new MTPingDelayDisconnect(Entropy.getInstance().generateRandomId(), PING_INTERVAL),
                        false, PING_INTERVAL_REQUEST, 0, context.getContextId(), false);
            }
        }
    }
}
 
開發者ID:rubenlagus,項目名稱:TelegramApi,代碼行數:14,代碼來源:MTProto.java

示例5: run

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
@Override
public void run() {
    setPriority(Thread.MIN_PRIORITY);
    while (!MTProto.this.isClosed) {
        if (Logger.LOG_THREADS) {
            Logger.d(MTProto.this.TAG, "Connection Fixer Iteration");
        }
        synchronized (MTProto.this.contexts) {
            if (MTProto.this.contexts.size() >= MTProto.this.desiredConnectionCount) {
                try {
                    MTProto.this.contexts.wait();
                } catch (InterruptedException e) {
                    return;
                }
            }
        }

        ConnectionType type = MTProto.this.connectionRate.tryConnection();
        TcpContext context = new TcpContext(MTProto.this, type.getHost(), type.getPort(), MTProto.this.tcpListener);
        context.connect();
        if (MTProto.this.isClosed) {
            return;
        }
        MTProto.this.scheduller.postMessageDelayed(new MTPing(Entropy.getInstance().generateRandomId()), false, PING_TIMEOUT, 0, context.getContextId(), false);
        synchronized (MTProto.this.contexts) {
            MTProto.this.contexts.add(context);
            MTProto.this.contextConnectionId.put(context.getContextId(), type.getId());
        }
        synchronized (MTProto.this.scheduller) {
            MTProto.this.scheduller.notifyAll();
        }
    }
}
 
開發者ID:rubenlagus,項目名稱:TelegramApi,代碼行數:34,代碼來源:MTProto.java

示例6: onError

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
@Override
public void onError(int errorCode, TcpContext context) {
    if (MTProto.this.isClosed) {
        return;
    }

    Logger.e(MTProto.this.TAG, "OnError (#" + context.getContextId() + "): " + errorCode);
    context.suspendConnection(true);
    context.connect();
    // Fully maintained at transport level: TcpContext dies
}
 
開發者ID:rubenlagus,項目名稱:TelegramApi,代碼行數:12,代碼來源:MTProto.java

示例7: closeConnections

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
public void closeConnections() {
    synchronized (contexts) {
        for (TcpContext context : contexts) {
            context.close();
            scheduller.onConnectionDies(context.getContextId());
        }
        contexts.clear();
        contexts.notifyAll();
    }
}
 
開發者ID:ardock,項目名稱:telegram-mt,代碼行數:11,代碼來源:MTProto.java

示例8: internalSchedule

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
private void internalSchedule() {
    long time = System.nanoTime() / 1000000;
    if (time - lastPingTime > PING_INTERVAL_REQUEST) {
        lastPingTime = time;
        synchronized (contexts) {
            for (TcpContext context : contexts) {
                scheduller.postMessageDelayed(
                        new MTPingDelayDisconnect(Entropy.generateRandomId(), PING_INTERVAL),
                        false, PING_INTERVAL_REQUEST, 0, context.getContextId(), false);
            }
        }
    }
}
 
開發者ID:ardock,項目名稱:telegram-mt,代碼行數:14,代碼來源:MTProto.java

示例9: onError

import org.telegram.mtproto.transport.TcpContext; //導入依賴的package包/類
@Override
public void onError(int errorCode, TcpContext context) {
    if (isClosed) {
        return;
    }

    Logger.d(TAG, "OnError (#" + context.getContextId() + "): " + errorCode);

    // Fully maintained at transport level: TcpContext dies
}
 
開發者ID:ardock,項目名稱:telegram-mt,代碼行數:11,代碼來源:MTProto.java


注:本文中的org.telegram.mtproto.transport.TcpContext類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。