Java Socket(一)

最近一直在看Socket,将自己的所学的记录一下。

[b]TCP/TP[/b]

不详细涉及,网络上有充足的信息,可以参考[url]http://baike.baidu.com/view/7729.htm[/url]。我说熟知的便是TCP/UDP属于传输层,而IP属于网络层。而IP提供了TCP/UDP网络传输的底层机制。

TCP提供检测和恢复IP层中通道可能造成的数据丢失以及其他错误。它的通道是基于byte-stream的,但是这个特点可能会造成报文接收不能与发送发一致,稍后谈这个问题。

UDP不对传输造成的错误进行修复,使用它时需要考虑处理这些问题。

Traditional Socket
再没有nio之前,一般使用blocking的方式编程。为了提高并发性,一般使用thrad-per-request的方式。

ss = new ServerSocket(10000);
while (true)
{
socket = ss.accept();
new Thread(new handle(socket)).start();//将处理丢给worker thread
}


当然这也有个问题,OS所能创建的thread是有限的,肯定不能无限制的创建,否则的话性能可能会不升反降。所以,可以采用thread pool的方式。1.5提供了很好的并发类库,所以可以将其修改为,

ArrayBlockingQueue workQueue = new ArrayBlockingQueue<Runnable>(20);
ThreadPoolExecutor excutor = new ThreadPoolExecutor(
20,
20,
60,
TimeUnit.SECONDS,
workQueue);
ss = new ServerSocket(10000);
while (true)
{
socket = ss.accept();
// new Thread(new handle(socket)).start();
excutor.execute(new handle(socket)); //handle by thread pool
}


[b]TCP Stream[/b]
解释一下上面提到的“报文接收不能与发送发一致”。这个问题很容易模拟出来,举个例子,
[quote]发送 1,2,3[/quote]
[quote]但是收到的却是 12,3[/quote]

看了一些资料,果然有本书提到这个问题,大意是,
[quote]若使用TCP,则不能假设在写入的输入流与输出流之间有任何联系。[/quote]
实际表现就是一个read()可能会获得多次write()的值。这个应该是取决于read()时使用的buffer的大小以及write()的时机。

关于这点我认为只需要keep in mind即可,呵呵 :oops: 。NIO在看,改天再录,最近一直在找关于NIO的长连接写法,教程和网上基本都是短连接的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值