从JDK1.4开始,Java引入了新的IO,在java.nio.*包中。引入新的IO目的在于提高IO的速度。速度的提高主要来自于:“通道和缓冲器”。
与通道直接交互的缓冲器是java.nio.ByteBuffer。
旧的文件IO类库中FileInputStream、FileOutputStream和RandomAccessFile被修改了,可以产生文件通道(FileChannel),但是Reader和Writer这些字符模式类不能产生通道。
下面,我使用NIO写了3个例子,分别是读文件、写文件和文件拷贝:
一、写文件
public void writeFileWithNio(File fileName, String content) throws IOException {
FileChannel channel = null;
try {
channel = new FileOutputStream(fileName).getChannel();
// 初始化缓冲器,长度为输入字符的字节数
ByteBuffer temp = ByteBuffer.allocate(content.getBytes("UTF-8").length);
temp.put(content.getBytes("UTF-8"));
// 调用此方法为一系列通道写入或相对获取 操作做好准备
temp.flip();
channel.write(temp);
// 强制输出,相当于flush
channel.force(true);
} finally {
if (channel != null && channel.isOpen() == true) channel.close();
}
}
二、读文件
public void readFileWithNio(File fileName) throws IOException {
FileChannel channel = null;
try {
channel = new FileInputStream(fileName).getChannel();
// 初始化缓冲器
ByteBuffer temp = ByteBuffer.allocate(1024);
int num = channel.read(temp);
// 调用此方法为一系列通道写入或相对获取 操作做好准备
temp.flip();
byte[] content = new byte[num];
temp.get(content);
System.out.println(new String(content,"UTF-8"));
} finally {
if (channel != null && channel.isOpen() == true) channel.close();
}
}
三、文件拷贝
public void copyFileWithNio(File originFile, File targetFile) throws IOException {
FileChannel inChannel = null;
FileChannel outChannel = null;
try {
inChannel = new FileInputStream(originFile).getChannel();
outChannel = new FileOutputStream(targetFile).getChannel();
// 拷贝,从输入通道的第0个开始,到输入通道的总长结束,目的地是输出通道
inChannel.transferTo(0, inChannel.size(), outChannel);
} finally {
if (inChannel != null && inChannel.isOpen() == true) inChannel.close();
if (outChannel != null && outChannel.isOpen() == true) outChannel.close();
}
}
以上3个都是非常简单的例子,只是用来学习罢了,要运用到实际中是不够的,尤其是读文件那个。
另外,旧的IO包实际上也已经使用NIO重新实现过,所以我们即使不使用NIO也可以从中获益的。
分享到:
相关推荐
Java NIO 网络编程初探 1. Java NIO Java 1.4 版本添加了一个新的IO API,称为NIO(New IO)。NIO拥有所有IO的功能,但是操作方法却完全不一样。NIO支持面向缓冲区的、基于通道的IO操作。能够更加高效的进行IO操作。...
3. **Selector(选择器)**:Netty 使用Java NIO中的选择器来监控多个通道的事件,减少了需要的线程数量,提高了系统的效率。 4. **NioEventLoop(NIO事件循环)**:每个EventLoop都是一个线程,负责处理其注册的...
它是一个 Java NIO(非阻塞 I/O)库,用于创建高并发、低延迟的网络服务。在 Java 社区中,Grizzly 以其灵活性和强大的功能而备受推崇,尤其适用于处理大量的并发连接。 **NIO基础** 在深入 Grizzly 之前,我们先...
- 自Java 7起,引入了NIO.2,提供更高效和更灵活的文件操作,如`Files`类中的静态方法,可以方便地进行文件操作,如复制、移动、删除等。 8. **字符编码**: - 文件读写时需考虑字符编码问题。默认的编码可能不...
不属于JVM规范定义的内存区域,但在高性能应用中常见,如NIO(New Input/Output)库,通过直接内存可以绕过Java堆,提高性能。 了解这些内存区域的工作原理和交互方式,可以帮助我们诊断和解决Java应用的内存泄漏...
### gRPC框架初探 #### 一、gRPC框架简介 gRPC是一个高效的远程过程调用(Remote Procedure Call,简称RPC)框架,由Google开发并开源。它支持多种编程语言,如C++、Java、Python、Go等,并利用HTTP/2进行传输层...
**袜子编程初探:构建网络通信的基础** 在IT领域,Socket编程是构建网络应用程序的核心技术之一,尤其对于网络通信的实现至关重要。本教程旨在为初学者提供一个基础的Socket编程学习路径,帮助理解网络通信的基本...
#### 1.14《How Tomcat Works》读书笔记(四):容器初探 - **容器概念**:Container是Tomcat中的核心组件之一,负责管理Web应用程序及其资源。 - **层级关系**:容器按照层次结构组织,包括Engine、Host、Context...
《构建Simple Songs Player应用——基于Java技术的音乐播放器初探》 在当前的数字化时代,音乐播放器已经成为人们生活中不可或缺的一部分。对于开发者而言,创建一个简易的音乐播放器是学习编程技能和深入理解...
#### 二、Jetty初探 **2.1 下载** 可以从Jetty官网或其他可信源下载Jetty。Jetty提供了多种版本,包括稳定版、测试版和快照版,可以根据需求选择合适的版本。 **2.2 安装** 安装Jetty相对简单,主要步骤包括: ...
<New id="httpConnector" class="org.eclipse.jetty.server.nio.SelectChannelConnector"> <Set name="host">localhost <Set name="port">8080 ``` **4.3 org.mortbay.xml.XmlConfiguration** `org....