java实现文件合并_Java实现文件分割和文件合并实例

文件切割和文件合并这个问题困扰了我有一段时间了(超过一天没做粗来)。

找了好多博客,本来想转载一个来的 结果找不到了。很无奈。

只好自己贴代码上了。

当然我会尽力好好写注释的。

文件切割器:

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.RandomAccessFile;

import java.util.Scanner;

public class Main {

public static void main(String[] args) throws FileNotFoundException, IOException {

File sourceFile = new File("ping.mp3");

// System.out.println(sourceFile.exists());

Scanner scanner = new Scanner(System.in);

int numberOfPieces = 1; //默认文件切割的数量

System.out.println("Enter:"); //提示输入

numberOfPieces = scanner.nextInt(); //输入

scanner.close(); //输入后就关闭 装完逼就跑一个道理

long fileLength = sourceFile.length() / numberOfPieces; //分一下每一个小文件的大小

byte[] b = new byte[1024]; //这个不解释 如果看不懂 就去看IO流去吧

RandomAccessFile raf1 = new RandomAccessFile(sourceFile, "r");

int len = -1;

for(int i = 0; i < numberOfPieces; i++) {

String name = sourceFile.getName() + "." + (i+1);

File file = new File(name);

file.createNewFile();

RandomAccessFile raf2 = new RandomAccessFile(file, "rw");

while((len = raf1.read(b)) != -1) {

raf2.write(b, 0, len); //我觉的这样写比raf2.write(b);高明一些

if(raf2.length() > fileLength) //如果太大了就不在这个子文件写了 换下一个

break;

}

raf2.close();

}

raf1.close();

}

}

文件合并器:

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.RandomAccessFile;

//文件合并 ping.n

public class Main {

public static void main(String[] args) throws FileNotFoundException, IOException {

File[] files = new File[10];

String name = "ping.";

File file = new File("ping.mp3");

file.createNewFile();

RandomAccessFile in = new RandomAccessFile(file, "rw");

in.setLength(0);

in.seek(0);

byte[] bytes = new byte[1024];

int len = -1;

for(int i = 0; i < files.length; i++) {

files[i] = new File(name + (i + 1));

//System.out.println(files[i].exists());

RandomAccessFile out = new RandomAccessFile(files[i], "rw");

while((len = out.read(bytes)) != -1) {

in.write(bytes, 0, len);

}

out.close();

}

in.close();

}

}

文件合并器就不写注释了,因为这是一个逆过程。(懒癌附体)

52c6608e5e73778eeafb6c62e75aa113.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/500237.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 线程池 资源回收_JAVA线程池资源回收的问题

最近项目中为了提高用户体验度&#xff0c;前台创建任务后台任务&#xff0c;用多线程来跑。现在的场景&#xff1a;后台定时任务管理这两个线程池&#xff0c;一个最大线程数10个&#xff0c;一个最大线程数15。应用部署之后&#xff0c;不超过5个小时&#xff0c;服务器负载高…

java 常量表达式_JavaSwitch语句:常量表达式是必需的,但它是常量

万千封印我知道编译器需要在编译时知道表达式才能编译一个开关&#xff0c;但是为什么foo.ba_常数不是呢&#xff1f;虽然从字段初始化后执行的任何代码的角度来看&#xff0c;它们都是常量&#xff0c;但它们不是编译时间常数在JLS所要求的意义上&#xff1b;见15.28常量表达式…

java post请求返回500错误信息_Retrofit API Post call 返回错误 500,适用于 Postman

我正在尝试使用改进 2 使用其他 API&#xff0c;我已经能够使用一些端点&#xff0c;但注册端点不断返回 http 500 错误代码&#xff0c;但在使用邮递员测试时工作正常。 POST("auth/signup/") Call addUser(Body SignUpCreds signUpCreds);这是注册凭据public class…

java 抽样_beta分布的采样或抽样(java程序)

beta分布的采样或抽样(java程序)标签&#xff1a;#beta分布采样#时间&#xff1a;2017/05/12 15:47:04作者&#xff1a;十七岁的雨季关于beta分布的介绍&#xff0c;请看我的另外一篇博客:http://blog.csdn.net/qy20115549/article/details/53307535本篇文章的另外地址为&#…

DP读书:《openEuler操作系统》(六)文件系统

10min速通文件系统 文件系统概述硬件基础磁盘和磁盘驱动器磁盘读写操作数据传输控制 文件系统中的基本概念文件目录文件系统 尽管内存的访问速度很快&#xff0c;但因其容量十分的有限&#xff0c;而且一旦断电&#xff0c;保存其中的数据就会丢失。用户希望数据保存的更大并且…

java web 开发技术大全 代码_Java Web开发技术大全

资深程序员全力打造&#xff0c;深入剖析SSH框架整合开发的精髓 全方位解读Java Web开发的基础知识、高级技术及应用案例 内容全面&#xff0c;讲解详细&#xff0c;全面覆盖JSP、Se rvlet、AJAX及SSH框架整合开发 避免冗长的理论讲解&#xff0c;而是直击主题&#xff0c;通过…

java nio doug_深入的聊聊 Java NIO

趁着三天假期&#xff0c;把Java NIO和Reactor模式整理总结了下&#xff0c;文章特别细节的知识点没有写&#xff0c;如一些API的具体实现。类似数据读到Buffer后再写出时&#xff0c;为什么需要复位操作&#xff0c;这些都属于NIO基础知识&#xff0c;是学习Reactor模式的前置…

java clone原理_详解Java中的clone方法 -- 原型模式

Java中对象的创建clone顾名思义就是复制&#xff0c; 在Java语言中&#xff0c; clone方法被对象调用&#xff0c;所以会复制对象。所谓的复制对象&#xff0c;首先要分配一个和源对象同样大小的空间&#xff0c;在这个空间中创建一个新的对象。那么在java语言中&#xff0c;有…

portal认证 java_华为5700交换机通过外部开源protal和本地aaa用户认证的一些问题

各位&#xff1a;您好&#xff0c;我通过一台华为5700交换机和一台portal服务器&#xff0c;想利用交换机本地的aaa认证&#xff0c;完成用户的上网认证。配置好后&#xff0c;用户可以重地向到portal页面&#xff0c;但是认证不能通过&#xff0c;具体配置如下&#xff1a;一、…

java复制一个对象_Java中对象的复制

假如说你想复制一个简单变量。很简单:1 int n 5;2 int m n;不仅仅是int类型&#xff0c;其它七种原始数据类型(boolean,char,byte,short,float,double.long)同样适用于该类情况。但是如果你复制的是一个对象&#xff0c;情况就有些复杂了。假设说我是一个beginner&#xff0c…

python判断是不是整数1002python判断是不是整数_Python判断一个数是不是为整数的方法...

Python判断一个数是不是为整数的方法发布时间&#xff1a;2020-07-08 15:44:30来源&#xff1a;亿速云阅读&#xff1a;84作者&#xff1a;清晨不懂Python判断一个数是不是为整数的方法&#xff1f;其实想解决这个问题也不难&#xff0c;下面让小编带着大家一起学习怎么去解决&…

spriteatlas 白屏的问题_Discuz白屏问题解决思

说到白屏&#xff0c;大家可能最先想到的就是dedecms了。Dedecms的白屏问题确实多&#xff0c;但是今天学习部小编要给大家介绍的是另一个大家耳熟能详的程序&#xff1a;discuz。说到discuz白屏&#xff0c;不少朋友感到非常头疼。为什么呢&#xff1f;Dz白屏的原因千奇百怪&a…

aix 超过一天的文件_Aix 6.1下 /dev/null 21 文件过大导致根目录爆满

原因&#xff1a;这是Aix6107系统下cas_agent软件的一个bug,原因是脚本写错了排查过程&#xff1a;1. 查看是哪个文件夹或哪个文件过大du -axg /|sort -rn|headls -ltr /dev/null*发现是 /dev/null 2>&1 过大&#xff0c;/dev只是存设备用的文件夹&#xff0c;文件都很…

HA集群实现原理 切换 JAVA_HA(一)高可用集群原理

高可用集群原理LVS集群DR模式简单的架构图如下所示&#xff1a;在上图的架构中&#xff0c;当Director服务器因软件、硬件、人为原因造成故障时&#xff0c;整个集群服务不可用&#xff0c;因此&#xff0c;需要再添加一台服务器实现Director服务高可用。整个系统的架构图如下所…

c语言指针没学可以学java_这是一篇来自刚脱离C语言的菜鸟所写下来的关于C语言之后转JAVA入门前期学习的感想...

/***My First writing*Name Li Tai Yue*Date 2018.12.14*/这是一篇来自刚脱离C语言的菜鸟所写下来的关于C语言之后转JAVA入门前期学习的感想。并且我也觉得这是一篇所有在校学习程序的小伙伴值得一看的文章。我想很多小伙帮都觉得敲代码是一件非常枯燥的事情&#xff0c;每天敲…

java outofmemory 处理_java.lang.OutOfMemoryError处理错误

原因&#xff1a; 常见的有以下几种&#xff1a;1.内存中加载的数据量过于庞大&#xff0c;如一次从数据库取出过多数据&#xff1b;2.集合类中有对对象的引用&#xff0c;使用完后未清空&#xff0c;使得JVM不能回收&#xff1b;3.代码中存在死循环或循环产生过多重复的对象实…

java queue 实现类 区别_Java集合11 (Queue)

java.util.Queue接口是java.util.Collection子接口。它代表一个有序的对象列表&#xff0c;就像List一样&#xff0c;但是它的使用有略微的区别。Queue被设计成从末端插入并且从头部删除的形式。Queue的实现类java.util.LinkedListjava.util.PriorityQueueLinkedList是一个非常…

实验四Java_《Java实验四》

实验4--附录三代码/*问题如下&#xff1a;编译如下代码&#xff0c;分析结果&#xff1b;将“注释这行”所在的行注释&#xff0c;再将注释的call2方法和main方法中的“StaticTest.call2(obj);”方去掉注释&#xff0c;再次编译&#xff0c;观察结果分析其原因。回答如下&#…

java是值调用_Java 只有值调用

在计算机科学中&#xff0c;参数传递的形式主要有以下2种: 值调用和引用调用,为了说明Java在传参过程中的参数传递方式&#xff0c;我们首先需要对上述中2种调用形式的定义做清晰的介绍定义现给出两者的定义:值调用(Call by Value): 指函数接收的是调用者提供的实参变量的值引用…

java 如何将数字倒置_每日一个小算法之整数中每位上的数字进行反转 20190810

题目要求&#xff1a;给出一个32位的有符号整数&#xff0c;你需要将这个整数中每位上的数字进行反转。示例 1:输入: 123输出: 321示例 2:输入: -123输出: -321示例 3:输入: 120输出: 21示例 4:输入&#xff1a;9646324351输出: 0注意&#xff1a;假设我们的环境只能存储得下 3…