jAVA基础 提高文件复制性能之多线程复制文件
利用IO流中的随机访问文件 RandomAccessFile 和文件通道 FileChanne 复制文件可大大提高文件的读写效率,在此基础上利用多线程复制文件使其性能更优。因线程的个数可根据文件的大小及需求而定。其大概原理是根据给定的线程个数,将文件分段,每个线程负责的数据大小=文件长度/线程个数,将不能除尽的部分留给最后一段文件所分配的线程处理。以下是实现代码及自己理解的注释,多有偏差请见谅。下面是兄弟连java培训
总结的一些代码:供参考。
程序实现类代码:
importjava.io.RandomAccessFile;
importjava.nio.channels.FileChannel;
importjava.nio.channels.FileLock;
//定义一个CopyThread类继承Thread类
public class CopyThreadextends Thread{
private String srcPath;//原文件地址
private String destPath;//目标文件地址
private int start,end;//start指定起始位置,end指定结束位置
//构造CopyThread方法
public CopyThread(StringsrcPath, 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 = newRandomAccessFile(srcPath, "r");
//创建一个可读可写的随机访问文件
RandomAccessFile out = newRandomAccessFile(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 voidmain(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 = newCopyThread(srcPath, destPath, oneNum * i,oneNum * (i + 1));
ct.start();
}
//文件长度不能整除的部分放到最后一段处理
CopyThread ct = newCopyThread(srcPath, destPath, oneNum * (count-1),(int)len);
ct.start();
}
}
jAVA基础 提高文件复制性能之多线程复制文件的更多相关文章
- Java基础 FileInputStream/ FileOutputStream / 字节输入流 字节输出流实现文件的复制
FileInputStream/FileOutputStream的笔记: /**(FileInputStream/FileOutputStream四个步骤: ①声明②加载地址③read/write④c ...
- Java 基础(四)| IO 流之使用文件流的正确姿势
为跳槽面试做准备,今天开始进入 Java 基础的复习.希望基础不好的同学看完这篇文章,能掌握泛型,而基础好的同学权当复习,希望看完这篇文章能够起一点你的青涩记忆. 一.什么是 IO 流? 想象一个场景 ...
- Java基础知识笔记(五:多线程的同步问题)
编写多线程程序往往是为了提高资源的利用率,或者提高程序的运行效率,或者更好地监控程序的运行过程等.多线程同步处理的目的是为了让多个线程协调地并发工作.对多线程进行同步处理可以通过同步方法和同步语句块实 ...
- Java基础知识笔记(四:多线程基础及生命周期)
一.多线程基础 编写线程程序主要是构造线程类.构造线程类的方式主要有两种,一种是通过构造类java.lang.Thread的子类,另一种是通过构造方法实现接口java.lang.Runnable的类. ...
- java基础第十六篇之多线程
1:线程的概念 进程(任务):一个正在运行的程序 进程的调度:CPU来决定什么时候该运行哪个进程 (时间片轮流法) 线程在一个应用程序中,同时,有多个不同的执行路径,是进程中的实际运作单位. 好处是提 ...
- Java基础之序列化对象——将对象写入到文件中(SerializeObjects)
控制台程序. 首先定义一个含有任意不同数据类型域的可序列化类: import java.io.Serializable; public class Junk implements Serializab ...
- JAVA多线程读写文件范例
在写之前先声明,本文是基于之前在博客园网站上检索到的一份JAVA多线程读写文件的示例,我在写自己的程序时是在那位作者写的基础上做了改良,但已不记得原文的地址.如果有知情者,烦请帖出地址,我在此文上加入 ...
- MySQL的并行复制多线程复制MTS(Multi-Threaded Slaves)
MySQL的并行复制多线程复制MTS(Multi-Threaded Slaves) http://www.tuicool.com/articles/m2Unmeq 姜承饶 简称MTS:基于binlog ...
- 黑马程序员——java基础之文件复制
---------------------- ASP.Net+Unity开发..Net培训.期待与您交流!---------------------- <a href="http:// ...
随机推荐
- laravel 使用PhantomMagick导出pdf ,在Linux下安装字体
git项目地址:https://github.com/anam-hossain/phantommagick sudo apt-get -y install fontconfig xfonts-util ...
- jenkins中通过Publish Over SSH将项目部署到远程机器上
Publish Over SSH插件使用在使用Publish Over SSH之前,需要制作SSH私钥.机器间做免密登录配置.假设机器A,ip为192.168.AA.AAA,机器B: 192.168. ...
- 应用安全 - 无文件式攻击 - 工具型攻击 - PowerShell - 汇总
PowerShell 使用 | 命令 win+r ->powershell #启动Powershell窗口 get-host #查看版本 Get-Host | Select-Object Ver ...
- Grafana配置文件
配置文件位置 /usr/local/opt/grafana/share/grafana/default.ini /usr/local/etc/grafana/grafana.ini 配置文件调用顺序 ...
- 洛谷P1347 排序
这个题看到很多人写Topo排序,其实这道题第一眼看更像是一个差分约束的裸题QWQ... 令dis[x]表示x的相对大小(1是最小,n是最大),显然,对于一个关系A<B,我们有dis[A]< ...
- Docker 容器(container)及资源限制
Container: 既然container是由image运行起来的,那么是否可以理解为container和image有某种关系?先来看张图: 其实可以理解为container只是基于image之后的 ...
- 《剑指offer》面试题26 复杂链表的复制 Java版
(定义一个新的数据结构,每个节点除了具有普通链表的next域外,还有一个额外的引用指向任意节点.我们要对由该特殊数据结构形成的链表进行复制.) 我的方法:也就是克隆一个这种特殊链表,很快想到先不考虑原 ...
- JDK集合框架源码分析 - 简单概要
1.类继承体系 在集合框架的类继承体系中,最顶层有两个接口Collection.Map: Collection 表示一组纯数据 Map 表示一组key-value对 Collection的类继承体系: ...
- python查询mysql中是否存在某张表(传参)
客户端输入了表的名字,服务端判断表是否存在. 参考:https://blog.csdn.net/qq_36523839/article/details/80639297 需要导入re模块: impor ...
- ECMAScript 6 学习笔记(一)
ECMAScript 6简介 ECMAScript 6.0(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.它的目标,是使得JavaScript语言可以用来编写 ...