自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

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

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

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

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

好了.上面的方法基本可以建立一條連線讓兩臺計算機相互交流了.可是數(shù)據(jù)是如何傳輸?shù)哪?事實上I/O操作總是和網(wǎng)絡(luò)編程息息相關(guān)的.因為底層的網(wǎng)絡(luò)是繼續(xù)數(shù)據(jù)的.除非遠程調(diào)用,處理問題的核心在執(zhí)行上.否則數(shù)據(jù)的交互還是依賴于IO操作的.所以你也必須導(dǎo)入java.io這個包.java的IO操作也不復(fù)雜.它提供了針對于字節(jié)流和Unicode的讀者和寫者,然后也提供了一個緩沖用于數(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)建不帶自動行刷新的新 PrintWriter。此便捷構(gòu)造方法創(chuàng)建必要的中間 OutputStreamWriter,后者使用默認字符編碼將字符轉(zhuǎn)換為字節(jié)。

上面兩句就是建立緩沖并把原始的字節(jié)流轉(zhuǎn)變?yōu)閁nicode可以操作.而原始的字節(jié)流來源于Java Socket多線程的兩個方法.getInputStream()和getOutputStream()方.分別用來得到輸入和輸出.那么現(xià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. }  

 

 

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

責(zé)任編輯:張浩 來源: 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

2010-03-19 17:04:01

Java socket

2018-11-28 09:53:50

游戲服務(wù)器線程

2015-07-09 09:49:39

PHPSocket服務(wù)器

2018-12-20 09:36:24

2011-06-30 18:03:58

QT 多線程 服務(wù)器

2010-03-18 19:39:44

Java Socket

2010-03-19 15:01:23

Java Socket

2012-02-15 10:34:29

JavaJava Socket

2010-03-16 17:00:02

Java多線程支持

2011-12-07 17:05:45

JavaNIO

2011-07-01 10:35:20

QT 多線程 TCP

2010-03-22 12:57:46

Java Socket

2010-03-17 18:04:55

java Socket
點贊
收藏

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