java 非阻塞io_使用InputStream的Java库实现非阻塞IO

我希望这对您的一些观点有所帮助:

1/2/3/4)Akka可以与使用java.io.InputStream和java.io.OutputStream的库一起很好地工作.参见本页,特别是本部分:http://doc.akka.io/docs/akka/snapshot/scala/io.html

A ByteStringBuilder can be wrapped in a java.io.OutputStream via the asOutputStream method. Likewise, ByteIterator can we wrapped in a java.io.InputStream via asInputStream. Using these, akka.io applications can integrate legacy code based on java.io streams.

1)您说通过网络获取文件.我通过HTTP猜测吗?您可以查看异步HTTP库.有很多相当成熟的异步HTTP库.我喜欢在Scala中使用Spray Client,因为它建立在akka之上,因此在akka环境中播放效果很好.它支持GZIP,但不支持PGP.

4)另一个选择:文件是否足够小以存储在内存中?如果是这样,您将不必担心异步,因为您将不会执行任何IO.等待IO时不会阻塞,而是因为内存速度很快而一直在使用CPU.

5)JDBC正在阻止.您以SQL查询作为参数调用方法,返回类型是包含数据的结果集.该方法必须在执行IO时阻塞才能返回此数据.

有一些Java async database drivers,但是我所看到的所有东西似乎都没有得到维护,因此我没有使用它们.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值