偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Java Socket多線程如何支持服務(wù)器模型

開(kāi)發(fā) 后端
Java Socket多線程如何才能更好的為我們服務(wù)呢?其實(shí)需要我們不斷在使用中尋找我們所需要的東西。下面我們就來(lái)實(shí)際的看看。

Java Socket多線程如何才能更好的使用呢?這就需要我們?cè)谟嘘P(guān)代碼上尋找答案。那么接下來(lái)我們就來(lái)看看有關(guān)Java Socket多線程的詳細(xì)介紹。希望大家在看了下文之后有所收獲。

網(wǎng)絡(luò)編程的基本模型就是客戶機(jī)到服務(wù)器模型.簡(jiǎn)單的說(shuō)就是兩個(gè)進(jìn)程之間相互通訊,然后其中一個(gè)必須提供一個(gè)固定的位置,而另一個(gè)則只需要知道這個(gè)固定的位置.并去建立兩者之間的聯(lián)系..然后完成數(shù)據(jù)的通訊就可以了.這里提供固定位置的通常稱為服務(wù)器,而建立聯(lián)系的通常叫做客戶端.基于這個(gè)簡(jiǎn)單的模型,就可以進(jìn)入網(wǎng)絡(luò)編程啦. #t#

Java對(duì)這個(gè)模型的支持有很多種Api.而這里我只想介紹有關(guān)Socket的編程接口.對(duì)于Java而言已經(jīng)簡(jiǎn)化了Java Socket多線程的編程接口.首先我們來(lái)討論有關(guān)提供固定位置的服務(wù)方是如何建立的.Java提供了ServerSocket來(lái)對(duì)其進(jìn)行支持.事實(shí)上當(dāng)你創(chuàng)建該類的一個(gè)實(shí)力對(duì)象并提供一個(gè)端口資源你就建立了一個(gè)固定位置可以讓其他計(jì)算機(jī)來(lái)訪問(wèn)你.ServerSocket server=new ServerSocket(6789);

這里稍微要注意的是端口的分配必須是唯一的.因?yàn)槎丝谑菫榱宋ㄒ粯?biāo)識(shí)每臺(tái)計(jì)算機(jī)唯一服務(wù)的.另外端口號(hào)是從0~65535之間的,前1024個(gè)端口已經(jīng)被Tcp/Ip 作為保留端口,因此你所分配的端口只能是1024個(gè)之后的.好了.我們有了固定位置.現(xiàn)在所需要的就是一根連接線了.該連接線由客戶方首先提出要求.因此Java同樣提供了一個(gè)Socket對(duì)象來(lái)對(duì)其進(jìn)行支持.只要客戶方創(chuàng)建一個(gè)Java Socket多線程的實(shí)例對(duì)象進(jìn)行支持就可以了.Socket client=new Socket(InetAddress.getLocalHost(),5678);客戶機(jī)必須知道有關(guān)服務(wù)器的IP地址.對(duì)于著一點(diǎn)Java也提供了一個(gè)相關(guān)的類InetAddress 該對(duì)象的實(shí)例必須通過(guò)它的靜態(tài)方法來(lái)提供.它的靜態(tài)方法主要提供了得到本機(jī)IP 和通過(guò)名字或IP直接得到InetAddress的方法.

好了.上面的方法基本可以建立一條連線讓兩臺(tái)計(jì)算機(jī)相互交流了.可是數(shù)據(jù)是如何傳輸?shù)哪?事實(shí)上I/O操作總是和網(wǎng)絡(luò)編程息息相關(guān)的.因?yàn)榈讓拥木W(wǎng)絡(luò)是繼續(xù)數(shù)據(jù)的.除非遠(yuǎn)程調(diào)用,處理問(wèn)題的核心在執(zhí)行上.否則數(shù)據(jù)的交互還是依賴于IO操作的.所以你也必須導(dǎo)入java.io這個(gè)包.java的IO操作也不復(fù)雜.它提供了針對(duì)于字節(jié)流和Unicode的讀者和寫者,然后也提供了一個(gè)緩沖用于數(shù)據(jù)的讀寫.

 

  1. BufferedReader in=new BufferedReader(new InputStreamReader
    (server.getInputStream()));   
  2. PrintWriter out=new PrintWriter(server.getOutputStream());  

 

注:public PrintWriter(OutputStream out)根據(jù)現(xiàn)有的 OutputStream 創(chuàng)建不帶自動(dòng)行刷新的新 PrintWriter。此便捷構(gòu)造方法創(chuàng)建必要的中間 OutputStreamWriter,后者使用默認(rèn)字符編碼將字符轉(zhuǎn)換為字節(jié)。

上面兩句就是建立緩沖并把原始的字節(jié)流轉(zhuǎn)變?yōu)閁nicode可以操作.而原始的字節(jié)流來(lái)源于Java Socket多線程的兩個(gè)方法.getInputStream()和getOutputStream()方.分別用來(lái)得到輸入和輸出.那么現(xiàn)在有了基本的模型和基本的操作工具.我們可以做一個(gè)簡(jiǎn)單的Java Socket多線程例程了.

服務(wù)方:

 

  1. import java.io.*;   
  2. import java.net.*;   
  3. public class MyServer {   
  4. public static void main(String[] args) throws 
    IOException{   
  5. ServerSocket server=new ServerSocket(5678);   
  6. Socket client=server.accept();   
  7. BufferedReader in=new BufferedReader(new InputStream
    Reader(client.getInputStream()));   
  8. PrintWriter out=new PrintWriter(client.getOutputStream());   
  9. while(true){   
  10. String str=in.readLine();   
  11. System.out.println(str);   
  12. out.println("has receive....");   
  13. out.flush();   
  14. if(str.equals("end"))   
  15. break;   
  16. }   
  17. client.close();   
  18. }   
  19. }  

 

 

這個(gè)程序的主要目的在于服務(wù)器不斷接收客戶機(jī)所寫入的信息只到.客戶機(jī)發(fā)送"End"字符串就退出程序.并且服務(wù)器也會(huì)做出"Receive"為回應(yīng).告知客戶機(jī)已接收到消息. 以上就是對(duì)Java Socket多線程的詳細(xì)介紹。

責(zé)任編輯:張浩 來(lái)源: it168
相關(guān)推薦

2010-03-17 17:54:25

java Socket

2010-03-16 10:50:21

Java多線程服務(wù)器

2010-03-16 13:47:48

Java多線程服務(wù)器

2009-02-18 10:41:16

多線程服務(wù)器穩(wěn)定Java

2009-02-27 11:15:00

多線程服務(wù)器MTS專用服務(wù)器

2018-01-11 08:24:45

服務(wù)器模型詳解

2011-12-08 13:04:06

JavaNIO

2018-11-28 09:53:50

游戲服務(wù)器線程

2010-03-19 17:04:01

Java socket

2015-07-09 09:49:39

PHPSocket服務(wù)器

2011-06-30 18:03:58

QT 多線程 服務(wù)器

2018-12-20 09:36:24

2010-03-18 19:39:44

Java Socket

2010-03-19 15:01:23

Java Socket

2012-02-15 10:34:29

JavaJava Socket

2011-12-07 17:05:45

JavaNIO

2010-03-16 17:00:02

Java多線程支持

2011-07-01 10:35:20

QT 多線程 TCP

2010-03-22 12:57:46

Java Socket

2010-03-18 20:00:35

Java socket
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)