`
Sunflower-13
  • 浏览: 74249 次
  • 性别: Icon_minigender_2
  • 来自: 长沙
社区版块
存档分类
最新评论

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

阅读更多

        利用IO流中的随机访问文件 RandomAccessFile  和文件通道 FileChanne 复制文件可大大提高文件的读写效率,在此基础上利用多线程复制文件使其性能更优。因线程的个数可根据文件的大小及需求而定。其大概原理是根据给定的线程个数,将文件分段,每个线程负责的数据大小=文件长度/线程个数,将不能除尽的部分留给最后一段文件所分配的线程处理。以下是实现代码及自己理解的注释,多有偏差请见谅。

 

 

程序实现类代码:

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();
 }
}

 

6
0
分享到:
评论
7 楼 Sunflower-13 2016-08-27  
elena_me 写道
elena_me 写道
不错,运行程序,拷贝600M的文件,用了0.4毫秒

我错了,测的不是线程执行时间,重新测试了一下,10秒左右  

6 楼 Sunflower-13 2016-08-27  
tieye 写道
Sunflower-13 写道
tieye 写道
好文章 顶起

过奖了

加油

谢谢你   
5 楼 elena_me 2016-08-26  
elena_me 写道
不错,运行程序,拷贝600M的文件,用了0.4毫秒

我错了,测的不是线程执行时间,重新测试了一下,10秒左右  
4 楼 elena_me 2016-08-26  
不错,运行程序,拷贝600M的文件,用了0.4毫秒
3 楼 tieye 2016-08-26  
Sunflower-13 写道
tieye 写道
好文章 顶起

过奖了

加油
2 楼 Sunflower-13 2016-08-25  
tieye 写道
好文章 顶起

过奖了
1 楼 tieye 2016-08-25  
好文章 顶起

相关推荐

    FileCopy1.rar_多文件复制_多线程复制

    在IT行业中,多文件复制和多线程复制是提高效率的关键技术,特别是在处理大量数据时。本文将深入探讨“FileCopy1.rar”压缩包中所包含的“多文件复制_多线程复制”这一主题。 首先,让我们理解什么是多文件复制。在...

    C#文件多线程复制代码

    在多线程复制文件时,如果无节制地创建线程,可能会导致系统资源过度消耗,甚至引起性能下降。因此,我们需要设定一个合理的最大线程数。这可以通过设置`ThreadPool.SetMaxThreads`来实现,同时配合`ThreadPool....

    FileCopy2.rar_MFC文件复制_mfc cwinthread_多线程复制_多线程类_文件复制MFC

    - **多线程复制**:意味着文件复制过程将在多个线程中并发执行,以提高效率。 - **多线程类**:指的是像CWinThread这样的类,它们帮助开发者管理多线程编程的复杂性。 - **文件复制mfc**:再次强调使用MFC进行文件...

    Delphi多线程实现文件拷贝

    在文件拷贝场景中,多线程可以使得大文件的复制过程更加流畅,不会阻塞用户界面,提升用户体验。 在Delphi中,我们可以使用`TThread`类来创建和管理线程。`TThread`是VCL(Visual Component Library)框架中的一个...

    文件复制——多线程

    在IT行业中,多线程是提高程序执行效率和并发能力的重要技术之一,尤其在处理大量数据,如文件复制时,其优势更为明显。本话题将深入探讨如何利用多线程来实现高效的文件复制。 首先,我们需要理解什么是多线程。在...

    文件夹遍历与多线程复制文件

    本项目"文件夹遍历与多线程复制文件"着重于五个关键知识点:文件夹非递归遍历、文件操作复制、多线程复制、线程互斥以及MFC非模态对话框的创建和销毁。下面将详细阐述这些知识点。 1. **文件夹非递归遍历**: 在...

    监听文件下文件发生变化时复制文件到另一个文件夹

    本案例的标题和描述提到了“监听文件下文件发生变化时复制文件到另一个文件夹”,这通常涉及到文件系统的观察者模式(Observer Pattern)和多线程技术。 首先,我们需要理解“监听文件”这一概念。在操作系统层面,...

    使用线程复制文件的改进

    在"使用线程复制文件的改进"这个程序中,开发者最初尝试利用临界区(Critical Section)来实现线程间的同步,但发现效果不尽如人意。于是,他们转向了事件(Event)作为新的同步机制,以期改善程序性能和并发控制。...

    微软多线程文件复制工具RichCopy 4

    据用户反馈,在本地到本地,本地到远程,远程到远程的文件复制过程中,RichCopy可以比XCOPY最大提高10倍的性能。 资源管理器集成 通常我们都使用资源管理器来进行文件剪切,复制和粘贴的操作。如果安装了...

    多线程拷贝小文件小工具

    标题中的“多线程拷贝小文件小工具”是指一种利用多线程技术来提高拷贝小文件效率的软件工具。在计算机编程中,多线程是并发处理的一种方式,它允许多个任务同时执行,从而提高程序的执行速度。在文件拷贝场景下,...

    qt 多线程实现样例,实现文件的拷贝

    在处理耗时操作如大文件复制时,为了保持UI的响应性和避免阻塞主线程,多线程技术显得尤为重要。本项目以"qt 多线程实现样例,实现文件的拷贝"为主题,通过使用 Qt 的 QThread 类来创建和管理后台线程,从而实现在...

    mfc文件浏览器实现文件拷贝功能多线程

    在本文中,我们将深入探讨如何使用Microsoft Foundation Class (MFC) 框架来实现一个文件浏览器,并且重点讲解如何在其中实现文件拷贝功能,同时利用多线程技术提高程序性能。MFC 是 Microsoft 提供的一个C++库,它...

    多线程复制(日文版)

    FastCopy是一款著名的文件复制工具,以其高性能和易用性著称,它支持多线程复制,能够在Windows操作系统上提供类似Unix的cp命令功能。在这个版本中,开发者可能已经优化了代码,提升了性能,或者添加了新的特性,如...

    文件复制算法 文件复制算法

    3. 并行复制:利用多线程或分布式系统,同时从源文件读取数据并写入多个目标位置,加快复制速度。这种方法尤其适用于大文件和网络环境。 4. 基于差异的复制:只复制源文件和目标文件之间的差异部分,如增量备份和...

    多线程对文件读写操作(java)

    在Java编程中,多线程技术是提升程序执行效率的关键之一,特别是在进行文件读写操作时。本主题将深入探讨如何使用多线程来优化文件的读取和写入过程,以及需要注意的相关问题。 首先,我们需要理解单线程与多线程在...

    使用线程复制文件

    本例中的"使用线程复制文件"是一个典型的多线程编程示例,主要目标是利用两个线程同时进行文件复制,以提高效率。下面我们将详细探讨这个主题。 一、线程基础 线程是操作系统分配CPU时间的基本单位,一个进程中可以...

    基于多线程的文件传输系统

    【基于多线程的文件传输系统】是一种网络编程技术,主要应用于提高文件传输效率和并发性能。在设计这样的系统时,通常会利用多线程的优势,使得多个文件传输任务可以在同一时间并行处理,从而缩短整体的传输时间。在...

    Windows 7系统使用多线程加快文件复制?.docx

    要使用RoboCopy进行多线程复制,可以使用以下命令格式: ``` Robocopy /s 源目录 目标目录 /E /MT:线程数 /LOG:日志文件名 ``` 这里: - `/s`表示包含子目录。 - `/E`表示复制空目录。 - `/MT:线程数`指定了使用...

    c++多线程文件分割

    在C++编程中,多线程技术是一种提升程序性能的有效方式,特别是在处理大文件或执行大量计算任务时。本文将深入探讨如何利用C++的多线程特性来实现文件的分割与合并操作。 首先,我们需要了解C++11引入的`&lt;thread&gt;`...

Global site tag (gtag.js) - Google Analytics