.Net和Java的socket机制比较

转帖|其它|编辑:郝浩|2009-02-02 13:32:44.000|阅读 753 次

概述:Java的TCP服务中使用的Socket是一种流机制,处理socket只需要从Socket中获取流,然后可以像处理本地流一样来进行数据的收发。.Net的Socket机制提供了两种实现:一种是直接用Socket类,一种是使用对Socket再次封装的TcpClient,UdpClient类来实现。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

文章关键字:|socket|机制|Java||.Net|TCP|接口|

  Sokcet是基于TCP和UDP协议的高层接口,定义了收发数据的格式。Java的TCP服务中使用的Socket是一种流机制,即对于编程人员来说,处理socket只需要从Socket中获取流,然后可以像处理本地流一样来进行数据的收发。

例如:

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

  .Net的Socket机制提供了两种实现:一种是直接用Socket类,一种是使用对Socket再次封装的TcpClient,UdpClient类来实现。.Net提供了一种统一的收发机制:NetworkStream。

  TcpClient和Socket的底层都是通过NetworkStream来传送数据的。它们都可以产生一个NetworkStream。例如:

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

  .Net的socket和Java的socket在收发数据上的最大不同是:Java的socket可以像普通的流一样操作。.Net的socket有多种实现方法,可以直接用Socket.send()来发,也可以用NetwordStream来发送,也可以用TcpClient来发送。但是每种实现在收发数据的时候都是通过显示的对缓冲区进行操作。例如:

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


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:CSDN

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP