我的位置: 首頁 > 學習專區(qū) > .NET技術 > .Net和Java的socket機制比較

.Net和Java的socket機制比較

2013-01-22 14:30:19
來源:
[導讀] socket是基于TCP和UDP協(xié)議的高層接口,定義了收發(fā)數(shù)據(jù)的格式。Java的TCP服務中使用的Socket是一種流機制,即對于編程人員來說,處理socket

socket是基于TCP和UDP協(xié)議的高層接口,定義了收發(fā)數(shù)據(jù)的格式。Java的TCP服務中使用的Socket是一種流機制,即對于編程人員來說,處理socket只需要從Socket中獲取流,然后可以像處理本地流一樣來進行數(shù)據(jù)的收發(fā)。

例如:

DataOutputStream outToClient =new DataOutputStream(socket.getOutputStream());BufferedReader inFromClient =new BufferedReader(new InputStreamReader(socket.getInputStream()));String requestMessageLine = inFromClient.readLine();outToClient.writeBytes(requestMessageLine);

.Net的Socket機制提供了兩種實現(xiàn):一種是直接用Socket類,一種是使用對Socket再次封裝的TcpClient,UdpClient類來實現(xiàn)。.Net提供了一種統(tǒng)一的收發(fā)機制:NetworkStream。

TcpClient和Socket的底層都是通過NetworkStream來傳送數(shù)據(jù)的。它們都可以產(chǎn)生一個NetworkStream。例如:

TcpClient client = server.AcceptTcpClient();NetworkStream stream = client.GetStream();

.Net的socket和Java的 socket在收發(fā)數(shù)據(jù)上的最大不同是:Java的socket可以像普通的流一樣操作。.Net的socket有多種實現(xiàn)方法,可以直接用 Socket.send()來發(fā),也可以用NetwordStream來發(fā)送,也可以用TcpClient來發(fā)送。但是每種實現(xiàn)在收發(fā)數(shù)據(jù)的時候都是通過 顯示的對緩沖區(qū)進行操作。例如:

byte[] datasize = new byte[4]; networkStream.Write(datasize,0,4);socket.Send(datasize, 0,datasize.Length, 0);

評論
熱點專題
>>
相關文章推薦
>>
好吊妞免费视频在线观看,久久亚洲国产人成综合网,久久精品国产2020,欧美精品综合在线
亚洲一区中文字幕 | 亚洲日韩一级在线毛 | 最新国产亚洲亚洲精 | 亚洲人成αⅴ网站在线 | 亚洲国产日本一区二区 | 天天摸天天添在线视频 |