国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器)

這篇具有很好參考價值的文章主要介紹了【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

一.TCP流套字節(jié)相關(guān)API.

Socket(既能給客戶端使用,也能給服務(wù)器使用)

構(gòu)造方法

【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議

基本方法:

【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議

ServerSocket(只能給服務(wù)器使用)

構(gòu)造方法:

【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議

基本方法:

【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議

二.TCP實現(xiàn)回顯服務(wù)器.

客戶端代碼示例:

package Demo2;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.util.Scanner;

public class TcpEchoClient {
    private Socket clientSocket =null;
    public TcpEchoClient(String serverIp,int serverPort) throws IOException {
        //此處可以把這里的IP和port直接傳給socket對象.
        //由于TCP是有連接的,所以socket中就會保存好這兩個信息.
        clientSocket = new Socket(serverIp,serverPort);
    }
    public void start(){
        System.out.println("客戶端啟動~~");
        try(InputStream inputStream = clientSocket.getInputStream();
            OutputStream outputStream = clientSocket.getOutputStream()
        ) {
            Scanner scannerConsole = new Scanner(System.in);
            //從控制臺讀取數(shù)據(jù)
            Scanner scannerNetWork = new Scanner(inputStream);
            //
            while(true){
                //1.從控制臺讀取數(shù)據(jù).
                System.out.println("->");
                if(!scannerConsole.hasNext()){
                    break;
                }

                String request = scannerConsole.next();
                PrintWriter printWriter = new PrintWriter(outputStream);
                //2.把請求發(fā)送給服務(wù)器. 這里要使用println來發(fā)送.為了讓發(fā)送的請求末尾帶有一個換行.
                printWriter.println(request);
                //通過flush來主動刷新緩沖區(qū),來確保數(shù)據(jù)發(fā)送到服務(wù)器了.
                printWriter.flush();
                //3.從服務(wù)器讀取響應(yīng).這里也是和服務(wù)器返回響應(yīng)的邏輯想對應(yīng)
                String response = scannerNetWork.next();
                //4.把響應(yīng)打印到控制臺.
                System.out.println(response);
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }

    public static void main(String[] args) throws IOException {
        TcpEchoClient client = new TcpEchoClient("127.0.0.1",9090);
        client.start();
    }
}

服務(wù)器代碼示例:

package Demo2;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class TcpEchoServer {
    private ServerSocket serverSocket = null;
    public TcpEchoServer(int port) throws IOException {
        serverSocket = new ServerSocket(port);
    }
    public void start() throws IOException {
        System.out.println("服務(wù)器啟動~~");
        ExecutorService pool = Executors.newCachedThreadPool();
        while(true) {
            //通過accept方法來接聽電話,然后才能進行通信.
            Socket clientSocket = serverSocket.accept();
//            Thread thread = new Thread(()->{
//                processConnection(clientSocket);
//            });
//            thread.start();
            pool.submit(new Runnable() {
                @Override
                public void run() {
                    processConnection(clientSocket);
                }
            });
        }

    }
    //通過這個方法來處理一次連接,連接過程中就會涉及請求響應(yīng)交互
    public void processConnection(Socket clientSocket){
        System.out.printf("[%s:%d] 客戶端上線!\n",clientSocket.getInetAddress(),clientSocket.getPort());
        //循環(huán)讀取客戶端的請求并返回響應(yīng)
        try(InputStream inputStream = clientSocket.getInputStream();
            OutputStream outputStream = clientSocket.getOutputStream()
        ) {
            Scanner scanner = new Scanner(inputStream);
            while(true){
                //可以通過inputStream來讀取數(shù)據(jù)了.
                //byte[] buffer = new byte[4096];
                //int n = inputStream.read(buffer);
                //此處讀操作完全可以用read來完成,但是read是把讀取到的數(shù)據(jù)放到一個byte數(shù)組之中
                //后續(xù)根據(jù)請求處理響應(yīng),還需要把數(shù)組轉(zhuǎn)化成字符串.
                //此時就可以使用Scanner來簡化這個過程.
                if(!scanner.hasNext()){
                    //讀取完畢,例如客戶端斷開鏈接.
                    System.out.printf("[%s %d] 客戶端下線!\n",clientSocket.getInetAddress(),clientSocket.getPort());
                    break;
                }
                //1.讀取請求并解析,此時有一個隱藏的約定,next讀的時候要讀到空白符才會結(jié)束
                //  因此就要求客戶端發(fā)來的請求必須帶有空白符結(jié)尾.比如帶有/n或" ".
                String request = scanner.next();
                //2.根據(jù)請求計算響應(yīng).
                String response = process(request);
                //3.把相應(yīng)給客戶端.
                //outputStream.write(response.getBytes(),0,response.getBytes().length);
                //  通過這種方式可以返回,但是這種方式不方便給返回的響應(yīng)中添加換行
                //  此時就可以給outputStream套一層來完成更方便的寫入.
                PrintWriter printWriter = new PrintWriter(outputStream);
                printWriter.println(response);
                printWriter.flush();
                System.out.printf("[%s %d] request : %s ;response : %s ",clientSocket.getInetAddress(),clientSocket.getPort(),request,response);
                System.out.println();
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }finally {
            try {
                clientSocket.close();
            } catch (IOException e) {
                throw new RuntimeException(e);
            }
        }
    }
    public String process(String request){
        return request;
    }

    public static void main(String[] args) throws IOException {
        TcpEchoServer server = new TcpEchoServer(9090);
        server.start();
    }
}

運行結(jié)果:
【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議
【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議文章來源地址http://www.zghlxwxcb.cn/news/detail-857365.html

代碼執(zhí)行流程:

  1. 服務(wù)器啟動,阻塞在accept,等待客戶端建立連接.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議
  2. 客戶端啟動.這里的new操作會觸發(fā)和服務(wù)器之間建立連接的操作.此時服務(wù)器就會從accept中返回.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議
  3. 服務(wù)器解除阻塞,繼續(xù)向下執(zhí)行,執(zhí)行processConnection方法
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議執(zhí)行這個方法,執(zhí)行到hasNext就會阻塞,此時雖然建立了連接,但是客戶端還沒有發(fā)來任何請求.hasNext阻塞等待到請求到達.
  4. 客戶端繼續(xù)執(zhí)行到hasNext,等待用戶向客戶端寫入內(nèi)容.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議
  5. 如果用戶真的輸入了,就會繼續(xù)向下執(zhí)行發(fā)送請求等待返回的邏輯.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議這里就會把請求真的發(fā)出去,同時客戶端等待服務(wù)器返回響應(yīng),此時next就會阻塞等待.
  6. 服務(wù)器從hasNext 返回讀取到的請求,構(gòu)造響應(yīng),并把響應(yīng)返回給客戶端.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議此時服務(wù)器結(jié)束此次循環(huán),開啟下一次循環(huán),繼續(xù)阻塞在hasNext等待下一個請求
  7. 客戶端讀取到響應(yīng),并顯示出來.
    【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器),網(wǎng)絡(luò),tcp/ip,服務(wù)器,java,網(wǎng)絡(luò)協(xié)議此時客戶端就會結(jié)束此次循環(huán),開啟下一次循環(huán),繼續(xù)阻塞在hasNext等待用戶輸入下一個請求.

代碼注意事項:

    1. flush()方法存在一個內(nèi)存緩沖區(qū).由于文件IO的操作比較低效,因此就希望IO的次數(shù)少一些,等攢到一定程度再進行IO操作.(相當(dāng)于多次IO合并成一次了). 因此就引入了緩沖區(qū),此時就會出現(xiàn)問題,你輸入的數(shù)據(jù)比較少,數(shù)據(jù)被存在內(nèi)存緩沖區(qū)了,所以需要我們手動刷新緩沖區(qū).
    1. 如果客戶端非常的多,就需要創(chuàng)建多個Socket對象,此時就可能導(dǎo)致系統(tǒng)的資源使用完了,因此需要在Socket執(zhí)行完畢之后關(guān)閉資源.
    1. 引入線程池來解決頻繁的創(chuàng)建銷毀線程.
    1. 如果有多個客戶端建立請求,并且長時間不銷毀
    • 解決方案一:引入?yún)f(xié)程===>輕量級線程,用戶態(tài)可以通過手動調(diào)度的方式讓一個線程并發(fā)的做多個任務(wù).
    • 解決方案二:IO多路復(fù)用===>這是一個系統(tǒng)內(nèi)核級別的機制,本質(zhì)上是讓一個線程去處理多個Socket對象 (這些Socket數(shù)據(jù)并非是同一時刻都需要處理).

到了這里,關(guān)于【網(wǎng)絡(luò)編程】TCP流套接字編程(TCP實現(xiàn)回顯服務(wù)器)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 網(wǎng)絡(luò)編程套接字( TCP )

    網(wǎng)絡(luò)編程套接字( TCP )

    目錄 1、實現(xiàn)一個TCP網(wǎng)絡(luò)程序(單進程版) ????????1.1、服務(wù)端serverTcp.cc文件 ?????????????????服務(wù)端創(chuàng)建套接字 ?????????????????服務(wù)端綁定 ?????????????????服務(wù)端監(jiān)聽 ?????????????????服務(wù)端獲取連接 ?????????????????服務(wù)

    2024年01月17日
    瀏覽(1816)
  • 【JaveEE】網(wǎng)絡(luò)編程之TCP套接字、UDP套接字

    【JaveEE】網(wǎng)絡(luò)編程之TCP套接字、UDP套接字

    目錄 1.網(wǎng)絡(luò)編程的基本概念 1.1為什么需要網(wǎng)絡(luò)編程? 1.2服務(wù)端與用戶端 1.3網(wǎng)絡(luò)編程五元組? 1.4套接字的概念 2.UDP套接字編程 2.1UDP套接字的特點 ?2.2UDP套接字API 2.2.1DatagramSocket類 2.2.2DatagramPacket類? 2.2.3基于UDP的回顯程序 2.2.4基于UDP的單詞查詢? 3.TCP套接字編程 3.1TCP套接字的特

    2023年04月13日
    瀏覽(915)
  • 【JavaEE】網(wǎng)絡(luò)編程之TCP套接字、UDP套接字

    【JavaEE】網(wǎng)絡(luò)編程之TCP套接字、UDP套接字

    目錄 1.網(wǎng)絡(luò)編程的基本概念 1.1為什么需要網(wǎng)絡(luò)編程? 1.2服務(wù)端與用戶端 1.3網(wǎng)絡(luò)編程五元組? 1.4套接字的概念 2.UDP套接字編程 2.1UDP套接字的特點 ?2.2UDP套接字API 2.2.1DatagramSocket類 2.2.2DatagramPacket類? 2.2.3基于UDP的回顯程序 2.2.4基于UDP的單詞查詢? 3.TCP套接字編程 3.1TCP套接字的特

    2023年04月20日
    瀏覽(120)
  • 【網(wǎng)絡(luò)編程】網(wǎng)絡(luò)編程套接字(三)TCP網(wǎng)絡(luò)程序

    【網(wǎng)絡(luò)編程】網(wǎng)絡(luò)編程套接字(三)TCP網(wǎng)絡(luò)程序

    與前邊的UDP網(wǎng)絡(luò)程序相同,創(chuàng)建套接字的接口都是socket,下邊對socket接口進行介紹: 協(xié)議家族選擇AF_INET,因為我們要進行網(wǎng)絡(luò)通信。 而第二個參數(shù),為服務(wù)類型,傳入SOCK_STREAM,我們編寫TCP程序,所以要選擇流式的服務(wù)。 第三個參數(shù)默認傳入0,由前兩個參數(shù)就可以推出這是

    2024年02月16日
    瀏覽(92)
  • 【Linux網(wǎng)絡(luò)】網(wǎng)絡(luò)編程套接字(TCP)

    【Linux網(wǎng)絡(luò)】網(wǎng)絡(luò)編程套接字(TCP)

    目錄 地址轉(zhuǎn)換函數(shù) 字符串IP轉(zhuǎn)整數(shù)IP 整數(shù)IP轉(zhuǎn)字符串IP 關(guān)于inet_ntoa 簡單的單執(zhí)行流TCP網(wǎng)絡(luò)程序 TCP socket API 詳解及封裝TCP socket? 服務(wù)端創(chuàng)建套接字? 服務(wù)端綁定? 服務(wù)端監(jiān)聽? 服務(wù)端獲取連接? 服務(wù)端處理請求 客戶端創(chuàng)建套接字 客戶端連接服務(wù)器 客戶端發(fā)起請求 服務(wù)器測試

    2024年03月21日
    瀏覽(113)
  • 【Java】網(wǎng)絡(luò)編程與Socket套接字、UDP編程和TCP編程實現(xiàn)客戶端和服務(wù)端通信

    【Java】網(wǎng)絡(luò)編程與Socket套接字、UDP編程和TCP編程實現(xiàn)客戶端和服務(wù)端通信

    為什么需要網(wǎng)絡(luò)編程? 現(xiàn)在網(wǎng)絡(luò)普及程序越來越高,網(wǎng)絡(luò)上保存著我們?nèi)粘I钪行枰母鞣N資源,使用程序通過網(wǎng)絡(luò)來獲取這些資源的過程就需要網(wǎng)絡(luò)編程來實現(xiàn)。 什么是網(wǎng)絡(luò)編程? 網(wǎng)絡(luò)編程,指網(wǎng)絡(luò)上的主機,通過不同的進程以程序的方式實現(xiàn)網(wǎng)絡(luò)通信(網(wǎng)絡(luò)數(shù)據(jù)傳輸)

    2024年02月17日
    瀏覽(91)
  • 【Linux】網(wǎng)絡(luò)---->套接字編程(TCP)

    【Linux】網(wǎng)絡(luò)---->套接字編程(TCP)

    TCP的編程流程:大致可以分為五個過程,分別是準備過程、連接建立過程、獲取新連接過程、消息收發(fā)過程和斷開過程。 1.準備過程:服務(wù)端和客戶端需要創(chuàng)建各自的套接字,除此之外服務(wù)端還需要綁定自己的地址信息和進行監(jiān)聽。注意:服務(wù)端調(diào)用listen函數(shù)后,處理監(jiān)聽狀

    2024年02月04日
    瀏覽(101)
  • Linux網(wǎng)絡(luò)編程——tcp套接字

    Linux網(wǎng)絡(luò)編程——tcp套接字

    本章Gitee倉庫:tcp套接字 客戶端: 客戶端: 關(guān)于構(gòu)造和初始化,可以直接在構(gòu)造的時候,將服務(wù)器初始化,那為什么還要寫到 init 初始化函數(shù)里面呢? 構(gòu)造盡量簡單一點,不要做一些“有風(fēng)險”的操作。 tcp 是面向連接的,通信之前要建立連接,服務(wù)器處于等待連接到來的

    2024年02月20日
    瀏覽(96)
  • 網(wǎng)絡(luò)編程套接字之三【TCP】

    網(wǎng)絡(luò)編程套接字之三【TCP】

    目錄 1. ServerSocket API(給服務(wù)器端使用的類) 2. Socket API(既給服務(wù)器使用,也給客戶端使用) 3. 寫TCP回顯—服務(wù)器 4. 使用線程池后的TCP服務(wù)器代碼(最終) 5. 寫回顯-客戶端 6. TCP回顯—客戶端代碼 7. 運行回顯服務(wù)器和客戶端 TCP流套接字編程 ?ServerSocket 是創(chuàng)建TCP服務(wù)端Socket的

    2024年01月19日
    瀏覽(92)
  • [Linux] 網(wǎng)絡(luò)編程 - 初見TCP套接字編程: 實現(xiàn)簡單的單進程、多進程、多線程、線程池tcp服務(wù)器

    [Linux] 網(wǎng)絡(luò)編程 - 初見TCP套接字編程: 實現(xiàn)簡單的單進程、多進程、多線程、線程池tcp服務(wù)器

    網(wǎng)絡(luò)的上一篇文章, 我們介紹了網(wǎng)絡(luò)變成的一些重要的概念, 以及 UDP套接字的編程演示. 還實現(xiàn)了一個簡單更簡陋的UDP公共聊天室. [Linux] 網(wǎng)絡(luò)編程 - 初見UDP套接字編程: 網(wǎng)絡(luò)編程部分相關(guān)概念、TCP、UDP協(xié)議基本特點、網(wǎng)絡(luò)字節(jié)序、socket接口使用、簡單的UDP網(wǎng)絡(luò)及聊天室實現(xiàn)…

    2024年02月16日
    瀏覽(32)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包