jAVA基础 提高文件复制性能之多线程复制文件

    jAVA基础 提高文件复制性能之多线程复制文件

利用IO流中的随机访问文件 RandomAccessFile 和文件通道 FileChanne 复制文件可大大提高文件的读写效率,在此基础上利用多线程复制文件使其性能更优。因线程的个数可根据文件的大小及需求而定。其大概原理是根据给定的线程个数,将文件分段,每个线程负责的数据大小=文件长度/线程个数,将不能除尽的部分留给最后一段文件所分配的线程处理。以下是实现代码及自己理解的注释,多有偏差请见谅。下面是兄弟连java培训总结的一些代码:供参考。
  程序实现类代码:
  import java.io.RandomAccessFile;
  import java.nio.channels.FileChannel;
  import java.nio.channels.FileLock;
  //定义一个CopyThread类继承Thread类
  public class CopyThread extends Thread{
  private String srcPath;//原文件地址
  private String destPath;//目标文件地址
  private int start, end;//start指定起始位置,end指定结束位置
  //构造CopyThread方法
  public CopyThread(String srcPath, String destPath, int start, int end) {
  this.srcPath = srcPath;//要复制的源文件路径
  this.destPath = destPath;//复制到的文件路径
  this.start = start;//复制起始位置
  this.end = end;//复制结束位置
  }
  //重写run()方法
  public void run() {
  try {
  //创建一个只读的随机访问文件
  RandomAccessFile in = new RandomAccessFile(srcPath, "r");
  //创建一个可读可写的随机访问文件
  RandomAccessFile out = new RandomAccessFile(destPath, "rw");
  in.seek(start);// 将输入跳转到指定位置
  out.seek(start);// 从指定位置开始写
  FileChannel inChannel = in.getChannel(); //文件输入通道
  FileChannel outChannel = out.getChannel();//文件输出通道
  //锁住需要操作的区域,false代表锁住
  FileLock lock = outChannel.lock(start, (end-start), false);
  //将字节从此通道的文件传输到给定的可写入字节的outChannel通道。
  inChannel.transferTo(start, (end-start), outChannel);
  lock.release();//释放锁
  out.close();//从里到外关闭文件
  in.close();//关闭文件
  } catch (Exception e) {
  e.printStackTrace();
  }
  }
  }
  测试类代码:
  import java.io.File;
  public class TestMain {
  public static void main(String[] args) {
  //要复制的源文件路径
  String srcPath = "F:\\sun\\上课笔记\\aa.txt";
  String destPath = "F:\\sun\\上课笔记\\aa复件.txt";
  // 获得源文件长度
  File f = new File(srcPath);
  long len = f.length();
  int count = 3;// 需要的线程数
  int oneNum = (int) (len / count);//每个线程负责的文件长度,强制转换成int类型
  //用for循环处理划分文件的第一部分跟第二部分(循环次数可根据定义的线程数调整)
  for (int i = 0; i < count - 1; i++) {
  //oneNum * i 起始位置, oneNum * (i + 1)要复制数据的长度
  CopyThread ct = new CopyThread(srcPath, destPath, oneNum * i,oneNum * (i + 1));
  ct.start();
  }
  //文件长度不能整除的部分放到最后一段处理
  CopyThread ct = new CopyThread(srcPath, destPath, oneNum * (count-1),(int)len);
  ct.start();
  }
  }

本页内容版权归属为原作者,如有侵犯您的权益,请通知我们删除。
这个是我一个技术相当好的哥们去面试的时候碰到的奇葩问题,那天,这个面试官的答案是不能。后来就带着这个问题去国内外的论坛上搜了一把,也是各说纷纭,实在是没有一个统一的答案,简直有点公说公有理,婆说婆有理的架势。     几个意见大致如下,第一,不能,因为“进程是CPU进行调度的单位,而JVM是一个进程,于是就只能跑在一个CPU上”。第二,“进程是CPU进行调度的单位,这没错,但是OS负责将一个进程在不同的CPU上调度到另外一个CPU上,而这个进程,则是由不同的线程构成的,那么说,线程还是在不同的CPU上运行了
1、一个简单的订单号生成器: 从代码可以看出: long orderNo = (Long.parseLong((date))) * 10000;   orderNo += orderNum + Long.parseLong(RandomStringUtils.randomNumeric(3)); 每毫秒可以保证,10000-999个订单号不重复。     import java.text.SimpleDateFormat;import java.util.Date;import org.apache.co
Java是世界上最流行的程序语言,从1995年问世以来,Java的生态系统在一直在蓬勃的发展着。作为一门健壮的技术,Java社区为广大开发者提供了包括框架、库、web开发sdk、JVM语言等资源。在各种科技行业都能够找到关于Java编程的相关资源,这就是为什么Java会如此受人喜爱。 在今天,发达的网络技术推动了Java的发展,越来越多的人选择在网上学习,查看技术大牛的博客并进行交流成为了日常学习的一个重要手段。在这里,我整理了国外最流行的十大Java技术博客,它们都是由Java技术专家维护的,无论是初学
druid是号称目前最好的java数据库连接池,温少写点代码中有很多设计模式的思想,其中最重要的一个就是filter-chain设计模式给druid所带来的可扩展性。对此,我很感兴趣,并希望日后借鉴,所以看了看他的源码,以此记录一下。 druid中设计到filter-chain设计模式的类或接口主要有一下几个Filter、FilterAdapter、FilterChain、FilterChainImpl、FilterEventAdapter、FilterManager 以及举例讲讲两个具体的filter:

mysql外键实战 - 2016-09-21 14:09:05

一、基本概念 1、MySQL中“键”和“索引”的定义相同,所以外键和主键一样也是索引的一种。不同的是MySQL会自动为所有表的主键进行索引,但是外键字段必须由用户进行明确的索引。用于外键关系的字段必须在所有的参照表中进行明确地索引,InnoDB不能自动地创建索引。 2、外键可以是一对一的,一个表的记录只能与另一个表的一条记录连接,或者是一对多的,一个表的记录与另一个表的多条记录连接。 3、如果需要更好的性能,并且不需要完整性检查,可以选择使用MyISAM表类型,如果想要在MySQL中根据参照完整性来建立表
会联网前沿技术文档,各大公司技术架构,欢迎各位浏览!!!网址: http://dwz.cn/4bwqKb  

Java的文件读写操作 - 2016-09-20 18:09:14

file(内存)----输入流----【程序】----输出流----file(内存) 当我们读写文本文件的时候,采用Reader是非常方便的,比如FileReader,InputStreamReader和BufferedReader。其中最重要的类是InputStreamReader, 它是字节转换为字符的桥梁。你可以在构造器重指定编码的方式,如果不指定的话将采用底层操作系统的默认编码方式,例如GBK等。使用FileReader读取文件: FileReader fr = new FileReader("mi

后端技术杂谈 - 2016-09-20 18:09:07

http://www.rowkey.me/blog/2016/06/27/java-backend-study/?hmsr=toutiao.ioutm_medium=toutiao.ioutm_source=toutiao.io       1、Web Server,Web container和Application Server区别。 Web Server,Web服务器,同上面所说,Web服务器是指能够为发出请求的浏览器提供文档的程序。服务器是一种被动程序,只有浏览器发出请求的时候才会响应。应用层使用的

JSP简单访问数据库 - 2016-09-20 17:09:01

Java代码 public class DBHelper { private String driverName; private String url; private String user; private String password; private Connection connection; private String createTableSql; private String dropTableSql; public void getConnection() { if (null =

微信jsapi扫一扫接口实现(4) - 2016-09-20 14:09:19

微信扫一扫功能在我们日常生活中很常见,那么微信jsapi是如何实现扫一扫功能的呢,接来下给大家详细介绍,并附有代码实现。 微信扫一扫  @V型知识库  原创 调起微信扫一扫接口 1 2 3 4 5 6 7 wx.scanQRCode({      needResult: 0,  // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,      scanType: [ "qrCode" , "barCode" ],  // 可以指定扫二维码还是一维码,默认二者都有      success:  func