Java IO流读取大数据文件

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
/**
 *
 * 用NIO把20g的文件分割开 生成到temp文件里
 * 然后再用传统的方法去读取每一个小文件
 */
public class ReadLargeTextWithNIO
{
 public static void main(String args[]) throws IOException
 {
  FileInputStream fin = new FileInputStream("C:\\TDDOWNLOAD\\query.log.td");
  FileChannel fcin = fin.getChannel();
  ByteBuffer buffer = ByteBuffer.allocate(1024 * 1024 * 50);
  while(true)
  {
   buffer.clear();
   int flag = fcin.read(buffer);
   if(flag == -1)
   {
    break;
   }
   buffer.flip();
   FileOutputStream fout = new FileOutputStream("d:\\temp\\" + Math.random() + ".log");
   FileChannel fcout = fout.getChannel();
   fcout.write(buffer);
   System.out.println(buffer);
  }
 }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值