`
ilrxx
  • 浏览: 65124 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

java nio与io性能测试

阅读更多

闲来无事,看到nio相关文章,于是想测试下nio和io的性能对比,不多说了,看下代码,大家一起讨论下,我觉得nio不是在性能方面对io的提升,而是其他方面的补充,比如阻塞和非阻塞io,不过这些概念理解比较差,还望赐教。

 

package com.nio;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;

public class CopyFile {
	public static void main(String[] args) throws Exception {
		Long startTime = System.currentTimeMillis();
		readWriteByIo();
//		readWriteFileByNio();
		Long endTime = System.currentTimeMillis();
		System.out.println("用时:" + (endTime - startTime));
	}

	public static void readWriteFileByNio() throws Exception {
//		String inFile = "d:/root.txt";
//		String outFile = "d:/target.txt";
		String inFile = "d:/my documents/view.log";
		String outFile = "d:/view.log";
		// 获取源文件和目标文件的输入输出流
		FileInputStream fin = new FileInputStream(inFile);
		FileOutputStream fout = new FileOutputStream(outFile);
		// 获取输入输出通道
		FileChannel fcin = fin.getChannel();
		FileChannel fcout = fout.getChannel();
		// 创建缓冲区
		ByteBuffer buffer = ByteBuffer.allocate(1024);
		while (true) {
			// clear方法重设缓冲区,使它可以接受读入的数据
			buffer.clear();
			// 从输入通道中将数据读到缓冲区
			int r = fcin.read(buffer);
			// read方法返回读取的字节数,可能为零,如果该通道已到达流的末尾,则返回-1
			if (r == -1) {
				break;
			}
			// flip方法让缓冲区可以将新读入的数据写入另一个通道
			buffer.flip();
			// 从输出通道中将数据写入缓冲区
			fcout.write(buffer);
		}
	}

	public static void readWriteByIo() throws FileNotFoundException {
//		String inFile = "d:/root.txt";
//		String outFile = "d:/target.txt";
		String inFile = "d:/my documents/view.log";
		String outFile = "d:/view.log";
		// 获取源文件和目标文件的输入输出流
		FileInputStream fin = new FileInputStream(inFile);
		FileOutputStream fout = new FileOutputStream(outFile);
		InputStreamReader isr = null;
		OutputStreamWriter osw = null;
		BufferedReader br = null;
		BufferedWriter bw = null;
		try {
			String line = null;
			isr = new InputStreamReader(fin, "utf-8");
			br = new BufferedReader(isr);
			osw = new OutputStreamWriter(fout, "utf-8");
			bw = new BufferedWriter(osw);
			while((line = br.readLine()) != null){
				bw.write(line + "\n");
			}
			bw.flush();
			fin.close();
			fout.close();
			isr.close();
			osw.close();
			br.close();
			bw.close();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

 测试结果:

使用java nio与java io读写文件性能对比
测试1:文件大小174M
nio用时:
第一次测试:用时:2906ms 
第二次测试:用时:3219ms
第三次测试:用时:2844ms
io用时:
第一次测试:用时:2718ms
第二次测试:用时:2047ms
第三次测试:用时:1984ms

测试2:文件大小3.09G
nio用时:
第一次测试:用时:228204ms
第二次测试:用时:231547ms
第三次测试:用时:249828ms
io用时:
第一次测试:用时:204594ms
第二次测试:用时:237672ms
第三次测试:用时:249672ms
0
0
分享到:
评论
1 楼 bempire 2014-07-22  
你的测试是不是有问题,我看别人做的测试,nio确实提高性能,你的反而降低了,

相关推荐

    Java NIO与IO性能对比分析.pdf

    本文将分析Java NIO与Java IO在性能上的对比,并尝试找出性能差异的原因,以及探讨哪种编程模型更适合高并发的应用场景。 Java IO模型是一种阻塞型I/O模型,在数据的读写过程中,如果线程在等待数据,将会一直被挂...

    深入Java NIO:释放IO性能的新维度

    ### 深入Java NIO:释放IO性能的新维度 #### 一、Java NIO的革新特性 ##### 1. 非阻塞 I/O 操作 非阻塞I/O操作是NIO的一个核心特性,它与传统的阻塞式I/O相比,在性能上有了质的飞跃。在传统的阻塞式I/O模型中,当...

    JAVA IO and NIO

    在IntelliJ IDEA中,开发者可以方便地使用Java IO和NIO编写和测试相关的代码。IDE提供了强大的代码补全、调试和测试工具,使得开发过程更加高效。对于Java IO,IntelliJ IDEA会自动处理流的关闭,对于NIO,它也提供...

    使用Java NIO编写高性能的服务器.doc

    Java NIO(New IO)是从JDK 1.4开始引入的一个新特性,它提供了一种不同于传统IO流的非阻塞I/O操作方式。NIO的核心在于它允许应用程序选择非阻塞的方式进行读写操作,从而提高了服务器处理大量并发连接的能力。NIO的...

    基于Java NIO反应器模式设计与实现

    综上所述,基于Java NIO的反应器模式设计与实现,可以大幅提升网络服务器的性能,通过非阻塞IO、事件驱动、选择器等机制,高效地处理高并发的数据传输任务,并且优化了线程资源的使用,减少了线程上下文切换的时间...

    java nio 聊天室源码

    Java NIO(New IO)是Java 1.4版本引入的一个新模块,全称为New Input/Output,是对传统IO API的扩展。它提供了一种更高效、更具选择性的IO操作方式,尤其适用于高并发和大数据处理场景。在这个“java nio 聊天室...

    Nio和Io的详细描述.docx

    Java NIO(New IO)是Java提供的一种替代标准Java IO和Java网络编程API的全新IO接口。NIO引入了一种不同于传统IO编程模型的机制。虽然有时人们将NIO理解为非阻塞IO,但这是不准确的。实际上,NIO API的部分功能,如...

    JAVA nio异步长连接服务端与客户端

    Java NIO(New IO)是Java 1.4版本引入的一个新特性,它提供了一种新的I/O操作方式,与传统的BIO(Blocking IO)模型相比,NIO具有更高的并发性能,尤其在处理大量连接请求时更为明显。NIO的核心在于非阻塞I/O,即在...

    java的各种io操作

    Java的IO操作是Java编程中的重要组成部分,它允许开发者处理输入和输出,包括读取文件、写入...同时,随着Java NIO(New IO)和NIO.2的引入,Java的IO性能和功能得到了显著提升,为开发者提供了更多高效和灵活的选择。

    基于java NIO的http代理,支持https.zip

    Java NIO(New IO)是Java 1.4版本引入的一个新特性,它为Java应用程序提供了非阻塞I/O操作的能力,与传统的IO模型(基于流的IO)相比,NIO具有更高的性能和更好的可扩展性。在本项目中,“基于java NIO的http代理,...

    JavaNIO非阻塞服务器示例.pdf

    NIO提供了与标准IO不同的I/O工作方式,它以非阻塞的方式处理网络通信,适用于高并发、低延迟的场景,如服务器端编程。在这个Java NIO非阻塞服务器示例中,我们看到如何使用Mina2.0框架来构建一个简单的服务器。 ...

    Java_nio&mina技术调研报告

    Java NIO(New Input/Output)是Java标准库中提供的一种I/O模型,与传统的BIO(Blocking I/O)模型相比,NIO具有更高的并发性能和更有效的资源管理能力。NIO的核心组件包括通道(Channels)、缓冲区(Buffers)和...

    Java NIO(通道+缓冲区+选择器)

    Java NIO,即Non-blocking Input/Output,是Java在JDK 1.4引入的一种新的I/O模型,它提供了一种不同于传统Java IO的高效处理大量数据的方式。NIO的核心概念包括通道(Channel)、缓冲区(Buffer)和选择器(Selector...

    Java_NIO框架Netty教程.pdf

    Java NIO(New IO)框架是Java平台中用于处理I/O操作的一种非阻塞I/O模型,相较于传统的IO模型,NIO提供了更高性能和更灵活的编程方式。Netty是基于Java NIO构建的一个高性能、异步事件驱动的网络应用程序框架,它极...

    Java NIO Selector选择器简介.pdf

    **Selector** 是 Java NIO (New I/O) 框架中的一个重要组成部分,主要用于检测一个或多个 **NIO Channel** 的状态,包括但不限于可读、可写、可连接或可接收等状态。它的引入主要是为了克服传统 BIO (Blocking I/O) ...

Global site tag (gtag.js) - Google Analytics