国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

一個簡單的支持多并發的socket服務/客戶端

Honwhy / 1867人閱讀

摘要:代碼實戰啟動類服務啟動類啟動類線程監聽端口服務類監聽端口主服務監聽端口服務端啟動成功,端口服務端啟動失敗線程模式,防止注釋啟動客戶端接受服務端異常客戶端接入監聽類客戶端接入監聽類數據連接值新客戶端接入對客戶端的業務處理,接收并重寫回去客戶

代碼實戰 ServerBoot啟動類
package com.example.demo.server;

/**
 * @author  MySelf
 * @create  2018/9/29
 * @desc 服務啟動類
 **/
public class ServerBoot {

    private static final int PORT = 8000;

    /**
     * 啟動Server類線程
     * @param args
     */
    public static void main(String[] args) {
        Server server = new Server(PORT);
        server.start();
    }

}
Server監聽端口服務類
package com.example.demo.server;

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

/**
 * @author  MySelf
 * @create  2018/9/29
 * @desc Server監聽端口主服務
 **/
public class Server {

    private ServerSocket serverSocket;

    /**
     * 監聽端口
     * @param port
     */
    public Server(int port){
        try {
            this.serverSocket = new ServerSocket(port);
            System.out.println("服務端啟動成功,端口:"+port);
        }catch (IOException e){
            System.out.println("服務端啟動失敗");
        }
    }

    /**
     * 線程模式,防止注釋
     */
    public void start(){
        new Thread(new Runnable() {
            @Override
            public void run() {
                doStart();
            }
        }).start();
    }

    /**
     * 啟動客戶端接受
     */
    private void doStart() {
        while (true){
            try {
                Socket client = serverSocket.accept();
                new ClientHandler(client).start();
            }catch (IOException e){
                System.out.println("服務端異常");
            }
        }
    }

}
ClientHandler客戶端接入監聽類
package com.example.demo.server;

import java.io.IOException;
import java.io.InputStream;
import java.net.Socket;

/**
 * @author  MySelf
 * @create  2018/9/29
 * @desc 客戶端接入監聽類
 **/
public class ClientHandler {

    /** 數據連接值 */
    public static final int MAX_DATA_LEN = 1024;
    private final Socket socket;

    public ClientHandler(Socket socket){
        this.socket = socket;
    }

    public void start(){
        System.out.println("新客戶端接入");
        new Thread(new Runnable() {
            @Override
            public void run() {
                doStart();
            }
        }).start();
    }

    /**
     * 對客戶端的業務處理,接收并重寫回去
     */
    private void doStart(){
        try {
            InputStream inputStream = socket.getInputStream();
            while (true){
                byte[] data = new byte[MAX_DATA_LEN];
                int len;
                while((len = inputStream.read(data)) != -1){
                    String message = new String(data,0,len);
                    System.out.println("客戶端傳來消息:"+message);
                    socket.getOutputStream().write(data);
                }
            }
        }catch (IOException e){
            e.printStackTrace();
        }
    }

}
Client客戶端啟動類
package com.example.demo.client;

import java.io.IOException;
import java.net.Socket;

/**
 * @author  MySelf
 * @create  2018/9/29
 * @desc 客戶端啟動類
 **/
public class Client {

    private static final String HOST = "127.0.0.1";
    private static final int PORT = 8000;
    private static final int SLEEP_TIME = 5000;

    public static void main(String[] args) throws IOException {

        final Socket socket = new Socket(HOST,PORT);

        /**
         * 客戶端啟動,定時向服務端發送數據
         */
        new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("客戶端啟動成功!");
                while (true){
                    try {
                        String message = "hello world";
                        System.out.println("客戶端發送數據:"+message);
                        socket.getOutputStream().write(message.getBytes());
                    }catch (Exception e){
                        System.out.println("寫數據出錯!");
                    }
                    sleep();
                }
            }
        }).start();
    }

    private static void sleep() {
        try {
            Thread.sleep(SLEEP_TIME);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

}
相關實戰

GitHub項目:基于Netty4與SpringBoot,聊天室WebSocket(文字圖片)、Iot物聯網-TCP/IP協議單片機通信,異步存儲聊天數據

如果本文對你有所幫助,歡迎關注技術公眾號。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77348.html

相關文章

  • PHP并發IO編程之路

    摘要:下文如無特殊聲明將使用進程同時表示進程線程。收到數據后服務器程序進行處理然后使用向客戶端發送響應。現在各種高并發異步的服務器程序都是基于實現的,比如。 并發 IO 問題一直是服務器端編程中的技術難題,從最早的同步阻塞直接 Fork 進程,到 Worker 進程池/線程池,到現在的異步IO、協程。PHP 程序員因為有強大的 LAMP 框架,對這類底層方面的知識知之甚少,本文目的就是詳細介...

    Riddler 評論0 收藏0
  • Nginx實現內參

    摘要:子進程啟動后監控維護區。每來一個新的連接都會觸發新的事件,這些事件送給內的狀態機來處理。大部分的邏輯上都有這樣的狀態機,只是實現方式不一樣。另外通過進程綁定技術可以進一步減少上下文切換和失效等系統開銷。 Nginx在web開發者眼中就是高并發高性能的代名詞,其基于事件的架構也被眾多開發者效仿。我從Nginx的網站找到一篇技術文章將Nginx是怎樣實現的,文章是Nginx的產品老大Owe...

    learn_shifeng 評論0 收藏0
  • 物聯網高并發編程之單臺服務器最大并發TCP連接數

    摘要:對端,通過增加內存修改最大文件描述符個數等參數,單機最大并發連接數超過萬甚至上百萬是沒問題的,國外公司在產品環境中已做到萬并發 [TOC] 前言 曾幾何時我們還在尋求網絡編程中C10K問題的解決方案,但是現在從硬件和操作系統支持來看單臺服務器支持上萬并發連接已經沒有多少挑戰性了。 我們先假設單臺服務器最多只能支持萬級并發連接,其實對絕大多數應用來說已經遠遠足夠了,但是對于一些擁有很大用...

    leap_frog 評論0 收藏0
  • 如何打造在線直播間(技術貼)

    摘要:背景當下視頻直播如此紅火,打造一個在線直播間涉及到哪些技術呢視頻直播由主播的直播端以及觀眾的觀看端組成。保持心跳斷開重連快速搭建在線直播間按前文所述,搭建直播間有非常多的細節需要考慮,包括采集推流分發播放體驗優化聊天室性能調優等。 背景 當下視頻直播如此紅火,打造一個在線直播間涉及到哪些技術呢? 視頻直播由主播的直播端以及觀眾的觀看端組成。一個簡單的觀看端最起碼應包含播放器以及聊天室。...

    sugarmo 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<