java nio

 

package com.part01;
import java.nio.Buffer;//是内存区域,类似于数组
import java.nio.ByteBuffer;
import org.junit.Test;
public class Demo01 {

	@Test//在方法上加@意味着可以被测试     JUnit(导jar包)
	public void testFlip()
	{
		
		ByteBuffer buffer = ByteBuffer.allocate(10);
		info(buffer);
		buffer.put((byte) 23);
		buffer.put((byte) 24);
		info(buffer);

		buffer.flip();// 将 position放到0 limit放到原position 的位置, p--l之间是有效数据
		info(buffer);
	}
	
	@Test
	public void testClean()
	{
		ByteBuffer buffer=ByteBuffer.allocate(10);
		info(buffer);
		buffer.put((byte) 23);
		buffer.put((byte) 24);
		info(buffer);
		buffer.flip();
		info(buffer);
		
		//将p放到0    l和c放到最末尾,等待下一次读
		buffer.clear();
		info(buffer);
		
	}
   @Test
	public void testremain()
	{
		ByteBuffer buffer=ByteBuffer.allocate(10);
		info(buffer);
		buffer.put((byte) 23);
		buffer.put((byte) 24);
		info(buffer);
		buffer.flip();
		info(buffer);
		
		//在p ---l这间有没有东西
		if(buffer.hasRemaining())
		{
			//p--l之间的东西个数
			System.out.println(buffer.remaining());
		}

	}
   @Test
	public void testwind()
	{
		ByteBuffer buffer=ByteBuffer.allocate(10);
		info(buffer);
		buffer.put((byte) 23);
		buffer.put((byte) 24);
		info(buffer);
	    //将p设为0,值没有没变
		buffer.rewind();
		info(buffer);
		
		System.out.println(buffer.get());
		System.out.println(buffer.get());

	}

	public static void info(Buffer buf)
	{
		System.out.println("position:"+buf.position()+"----limit:"+buf.limit()+"----->capacity"+buf.capacity());
	}
}

依次测试testFlip,testClean,testremain,testwind结果如下:

position:0----limit:10----->capacity10
position:2----limit:10----->capacity10
position:0----limit:2----->capacity10

position:0----limit:10----->capacity10
position:2----limit:10----->capacity10
position:0----limit:2----->capacity10
position:0----limit:10----->capacity10

position:0----limit:10----->capacity10
position:2----limit:10----->capacity10
position:0----limit:2----->capacity10
2

position:0----limit:10----->capacity10
position:2----limit:10----->capacity10
position:0----limit:10----->capacity10
23
24


 

 

Bytebuffer与字符串之间的互转 

package com.part01;
//java.nio.charset.Charset类
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.charset.Charset;
import org.junit.Test;
/*CharBuffer  decode(ByteBuffer bb)  将此 charset 中的字节解码成 Unicode 字符的便捷方法。 
  ByteBuffer encode(String str)   将此 charset中的字符串编码成字节的便捷方法。       
  static Charset forName(String charsetName)  返回指定 charset的charset 对象。 
  defaultCharset() 返回此 Java虚拟机的默认 charset。  */
         
public class Demo02
{
	@Test
   public void bytebuffer2string()//ByteBuffer转字符串
   {
	   ByteBuffer buf=ByteBuffer.allocate(10);
	   buf.put((byte)97);
	   buf.put((byte)98);
	   buf.put((byte)99);
	   buf.flip();
	   
	   CharBuffer charbuffer=Charset.defaultCharset().decode(buf);
	   System.out.println(charbuffer);
	   
   }
	
	@Test
	public void String2ByteBuffer()//字符串转ByteBuffer
	{
		String str="abc";
	    Charset charset=Charset.forName("utf-8");
	    ByteBuffer buf=charset.encode(str);
	    
	    System.out.println("position:"+buf.position()+"----limit:"+buf.limit()+"----->capacity"+buf.capacity());
	}
}

nio的思想和实现 

写东西

package com.part01;

import java.io.FileNotFoundException;
public class Demo03 {
	public static void main(String[] args) throws IOException 
	{
		FileOutputStream fo=new FileOutputStream("d:\\iodemo.txt");
		//输出流得到的FileChannel只能输出
		FileChannel  fc=fo.getChannel();
		String str="张三回来了吗";
     	ByteBuffer buf=Charset.defaultCharset().encode(str);
		
		fc.write(buf);
		fc.close();
		fo.close();
		System.out.println("OK");
	}
}

 等同于

package com.part01;

import java.io.FileOutputStream;
public class Demo04 {

	public static void main(String[] args) throws IOException 
	{
		FileOutputStream fo=new FileOutputStream("d:\\iodemo.txt");
		//输出流得到的FileChannel只能输出
		FileChannel  fc=fo.getChannel();
		
		String str="张三回来了吗";
		byte[] data=str.getBytes();
     	ByteBuffer buf=ByteBuffer.allocate(50);
     	buf.put(data);
     	buf.flip();//p--l之间的有效数
		fc.write(buf);//channel可以读写buffer
		fo.close();
		fc.close();
		System.out.println("OK");
	}
}

读东西

package com.part01;

import java.io.FileInputStream;
public class Demo05 {

	public static void main(String[] args) throws Exception{
    // Charset set=Charset.defaultCharset();
		//输入流得到的FileChannel只能写
     FileInputStream fi=new FileInputStream("d:\\iodemo.txt");
     FileChannel fc=fi.getChannel();
     
     ByteBuffer buf=ByteBuffer.allocate(4096);
     info(buf);
     
     int len=-1;
     
    while((len=fc.read(buf))>0)
    {
    	  info(buf);
    	  buf.flip();
    	  String str=Charset.defaultCharset().decode(buf).toString();
    	  System.out.println(str);
    	  buf.clear();//在下一次读之前 
    	 
    }
     fc.close();
     fi.close();
	}
	public static void info(Buffer buf)
	{
		System.out.println("position:"+buf.position()+"----limit:"+buf.limit()+"----->capacity"+buf.capacity());
	}
}
//在ByteBuffer里面拿数据的时候,一定要先flip
//从流中往ByteBuffer中读数据一定要clear

用java.nio来复制文件(虚拟内存映射模式)

package com.part10;

import java.io.FileInputStream;
//用java.nio来复制文件(虚拟内存映射模式)
public class Demo06 {

	public static void main(String[] args) throws IOException 
	{
		FileInputStream fi=new FileInputStream("D:\\tools\\eclipse-jee-oxygen-3-win32-x86_64.zip");
		FileOutputStream fo=new FileOutputStream("c:\\eclipse.zip");
		
		FileChannel  fic=fi.getChannel();
		FileChannel  foc=fo.getChannel();
		
		ByteBuffer buffer=ByteBuffer.allocate(4096);
		long start= System.currentTimeMillis();
		int len=-1;
		
          while((len=fic.read(buffer))>0)//读到数据,要把数据写到输出流
          {
        	  buffer.flip();
        	  foc.write(buffer);
        	  buffer.clear();//在下一次读之前
          }
          fic.close();
          foc.close();
          
          long end= System.currentTimeMillis();
          
          System.out.println((end-start)/1000.0);
	}

}

 

 

 

 

 

 

03-15
### Java NIO 教程与文档 Java NIO 是一种基于缓冲区和通道的 I/O 处理方式,相较于传统的 Java IO 更高效且适合处理大规模数据传输。以下是关于 Java NIO 的一些核心概念及其学习资源。 #### 1. **核心组件** Java NIO 主要由以下几个部分组成: - **Buffer**: 数据容器,用于存储不同类型的原始数据[^4]。 - **Channel**: 类似于流的概念,但支持双向读写操作。 - **Selector**: 支持多路复用机制,允许单线程管理多个 Channel。 这些组件共同构成了高效的非阻塞 I/O 模型,适用于网络编程和文件操作场景。 #### 2. **官方文档** Oracle 官方文档提供了详尽的 Java NIONIO.2 API 描述以及使用示例。可以通过访问 Oracle 官网并搜索 "Java SE documentation" 来获取最新的官方文档[^3]。 #### 3. **教程推荐** Baeldung 网站上的教程涵盖了 Java NIO 的基本原理及高级应用案例。例如,“Five ways to maximize Java NIO and NIO.2” 提供了五个重要的功能介绍,包括变更通知器(Change Notifiers),这使得监听事件变得更加简单。 #### 4. **实际应用场景** 通过结合实例代码可以更好地理解如何利用 Java NIO 实现高性能的数据传输。例如,在文件写入方面有多种实现方法,既可以直接采用标准库中的 `Files` 工具类,也可以借助更底层的 Buffer 和 Channel 结构完成复杂任务[^1]。 ```java import java.nio.file.*; import java.io.IOException; public class FileWriteExample { public static void main(String[] args) throws IOException { Path path = Paths.get("example.txt"); String content = "This is a test."; // 使用 Files.write 方法快速写入字符串到文件 Files.write(path, content.getBytes()); } } ``` 上述代码展示了如何利用 `Files.write()` 函数向指定路径下的文件写入一段文本内容。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值