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
    评论
### 回答1: 下面是一个使用 Java 语言实现的 Socket 长连接服务器端的示例代码: ``` import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.util.Iterator; public class Server { public static void main(String[] args) throws IOException { // 创建 ServerSocketChannel,监听 8888 端口 ServerSocketChannel ssc = ServerSocketChannel.open(); ssc.socket().bind(new InetSocketAddress(8888)); // 设置为非阻塞模式 ssc.configureBlocking(false); // 为 ssc 注册选择器 Selector selector = Selector.open(); ssc.register(selector, SelectionKey.OP_ACCEPT); // 创建处理器 Handler handler = new Handler(); while (true) { // 等待请求,每次等待阻塞 3s,超过 3s 后线程继续向下运行,等待下一次请求 if (selector.select(3000) == 0) { System.out.println("等待请求超时。。。"); continue; } System.out.println("处理请求。。。"); // 获取待处理的 SelectionKey Iterator<SelectionKey> keyIter = selector.selectedKeys().iterator(); while (keyIter.hasNext()) { SelectionKey key = keyIter.next(); try { // 接收到连接请求时 if (key.isAcceptable()) { handler.handleAccept(key); } // 读数据 if (key.isReadable()) { handler.handleRead(key); } } catch (IOException e) { keyIter.remove(); continue; } // 处理完后,从待处理的 SelectionKey 迭代器中移除当前所使用的 key keyIter.remove(); } } } } class Handler { private int bufferSize = 1024; private String localCharset = "UTF-8"; ### 回答2: 以下是一个使用Java实现的Socket服务器端代码示例,实现了长连接和非阻塞通信: ```java import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.*; import java.util.Iterator; import java.util.Set; public class Server { private static final int PORT = 8888; private ServerSocketChannel serverSocketChannel; private Selector selector; private ByteBuffer buffer; public Server() { try { serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket().bind(new InetSocketAddress(PORT)); serverSocketChannel.configureBlocking(false); selector = Selector.open(); serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT); buffer = ByteBuffer.allocate(1024); } catch (IOException e) { e.printStackTrace(); } } public void start() { try { System.out.println("Server started on port " + PORT); while (true) { selector.select(); Set<SelectionKey> selectedKeys = selector.selectedKeys(); Iterator<SelectionKey> iterator = selectedKeys.iterator(); while (iterator.hasNext()) { SelectionKey key = iterator.next(); iterator.remove(); if (key.isAcceptable()) { handleAccept(key); } else if (key.isReadable()) { handleRead(key); } } } } catch (IOException e) { e.printStackTrace(); } } private void handleAccept(SelectionKey key) throws IOException { SocketChannel clientChannel = ((ServerSocketChannel) key.channel()).accept(); clientChannel.configureBlocking(false); clientChannel.register(selector, SelectionKey.OP_READ); System.out.println("Client connected: " + clientChannel.getRemoteAddress()); } private void handleRead(SelectionKey key) throws IOException { SocketChannel clientChannel = (SocketChannel) key.channel(); int bytesRead = clientChannel.read(buffer); if (bytesRead == -1) { clientChannel.close(); return; } buffer.flip(); byte[] bytes = new byte[buffer.remaining()]; buffer.get(bytes); String message = new String(bytes).trim(); System.out.println("Received message: " + message); buffer.clear(); } public static void main(String[] args) { Server server = new Server(); server.start(); } } ``` 以上代码创建了一个Server类,包含了服务器的主要逻辑。该服务器会在指定端口上监听客户端的连接请求,并在服务器收到消息时打印消息内容。 该代码使用非阻塞模式,可以同时处理多个客户端的连接和消息读取。在start方法中,通过Selector来实现非阻塞的监听,当服务器收到新的连接请求或收到消息时,会相应地执行相应的处理方法。 注意,该代码只是示例,没有包含完整的错误处理和客户端消息发送等功能,仅供参考和理解使用。实际应用中需要根据具体需求进行扩展和完善。 ### 回答3: Socket通信是一种实现客户端和服务器端之间数据交换的通信方式。服务器端负责接收来自客户端的请求并处理,而客户端负责向服务器端发送请求并接收响应。 实现Socket通信的服务器端可以使用Java语言编写。下面是一个使用Java代码示例实现的Socket服务器端(长连接,非阻塞): ```java import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.ServerSocket; import java.net.Socket; public class SocketServerExample { public static void main(String[] args) { try { // 创建服务器端Socket对象,指定端口号 ServerSocket serverSocket = new ServerSocket(8888); while (true) { // 监听客户端的连接请求 Socket socket = serverSocket.accept(); // 创建用于接收客户端请求的线程 Thread thread = new RequestHandler(socket); thread.start(); } } catch (IOException e) { e.printStackTrace(); } } } // 处理客户端请求的线程类 class RequestHandler extends Thread { private Socket socket; public RequestHandler(Socket socket) { this.socket = socket; } @Override public void run() { try { // 获取输入流,用于接收客户端发送的数据 InputStream is = socket.getInputStream(); // 获取输出流,用于向客户端发送数据 OutputStream os = socket.getOutputStream(); // 处理客户端发送的数据并返回响应 byte[] buffer = new byte[1024]; int len; while ((len = is.read(buffer)) != -1) { // 处理客户端发送的数据 // 向客户端发送响应数据 os.write("Server response".getBytes()); os.flush(); } // 关闭流和Socket连接 is.close(); os.close(); socket.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上代码示例中,首先创建ServerSocket对象,并指定端口号8888。然后通过while循环接收客户端的连接请求,每次接收到连接请求后,创建一个用于处理客户端请求的线程,并启动该线程。 在RequestHandler线程类中,通过获取Socket的输入流和输出流来实现与客户端的数据交互。利用输入流从客户端接收数据,并利用输出流向客户端发送响应数据。 需要注意的是,这是一个简单的Socket服务器端示例,每当有一个客户端连接请求时,会创建一个新的线程来处理。在实际应用中,可能需要更多的处理逻辑和考虑并发处理的情况。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值