91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SocketChannel在java中如何實現客戶端

發布時間:2022-05-31 16:31:01 來源:億速云 閱讀:267 作者:iii 欄目:大數據

這篇文章主要介紹“SocketChannel在java中如何實現客戶端”,在日常操作中,相信很多人在SocketChannel在java中如何實現客戶端問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”SocketChannel在java中如何實現客戶端”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1、步驟

(1)創建SocketChannel實例,并將其配置為非阻塞模式,只有在SocketChannel實例中,任何I/O操作都是非阻塞的。

(2)使用connect()方法連接服務器,同時使用while循環連續檢測和完全連接。在需要立即進行I/O操作之前,必須使用finishConnect()來完成連接過程。

(3)用ByteBuffer讀寫字節,假如SelectableChannel是一種非阻塞模式,那么它的I/O操作讀寫字節可能比實際字節少,甚至沒有。因此,我們使用循環連續的讀寫來確保讀寫完成。

2、實例

public class NonBlockingTCPClient {
    public static void main(String[] args) {
        byte[] data = "hello".getBytes();
        SocketChannel channel = null;
        try {
            // 1. open a socket channel
            channel = SocketChannel.open();
            // adjust to be nonblocking
            channel.configureBlocking(false);
            // 2. init connection to server and repeatedly poll with complete
            // connect() and finishConnect() are nonblocking operation, both return immediately
            if (!channel.connect(new InetSocketAddress(InetAddress.getLocalHost(), 8899))) {
                while (!channel.finishConnect()) {
                    System.out.print(".");
                }
            }
 
            System.out.println("Connected to server...");
 
            ByteBuffer writeBuffer = ByteBuffer.wrap(data);
            ByteBuffer readBuffer = ByteBuffer.allocate(data.length);
            int totalBytesReceived = 0;
            int bytesReceived;
            // 3. read and write bytes
            while (totalBytesReceived < data.length) {
                if (writeBuffer.hasRemaining()) {
                    channel.write(writeBuffer);
                }
                if ((bytesReceived = channel.read(readBuffer)) == -1) {
                    throw new SocketException("Connection closed prematurely");
                }
                totalBytesReceived += bytesReceived;
                System.out.print(".");
            }
            System.out.println("Server said: " + new String(readBuffer.array()));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            // 4 .close socket channel
            try {
                if (channel != null) {
                    channel.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

到此,關于“SocketChannel在java中如何實現客戶端”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平安县| 长兴县| 申扎县| 临潭县| 太白县| 绍兴县| 阜新| 黎川县| 黑龙江省| 黄陵县| 吉林省| 富平县| 霍林郭勒市| 鹿邑县| 普兰县| 涿鹿县| 应城市| 个旧市| 灵寿县| 那坡县| 甘德县| 化隆| 新干县| 怀来县| 海兴县| 黑河市| 斗六市| 连州市| 伊吾县| 巫溪县| 顺义区| 南雄市| 宜良县| 兴国县| 巩留县| 双牌县| 历史| 沂源县| 航空| 勃利县| 梁山县|