亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java實(shí)現(xiàn)文件分割和文件合并實(shí)例

 更新時(shí)間:2017年08月01日 08:50:55   作者:左世鈺  
本篇文章主要介紹了Java實(shí)現(xiàn)文件分割和文件合并實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

文件切割和文件合并這個(gè)問(wèn)題困擾了我有一段時(shí)間了(超過(guò)一天沒(méi)做粗來(lái))。

找了好多博客,本來(lái)想轉(zhuǎn)載一個(gè)來(lái)的 結(jié)果找不到了。很無(wú)奈。

只好自己貼代碼上了。

當(dāng)然我會(huì)盡力好好寫(xiě)注釋的。

文件切割器:

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;  //默認(rèn)文件切割的數(shù)量
  System.out.println("Enter:");  //提示輸入
  numberOfPieces = scanner.nextInt();  //輸入
  scanner.close();  //輸入后就關(guān)閉 裝完逼就跑一個(gè)道理
  long fileLength = sourceFile.length() / numberOfPieces;  //分一下每一個(gè)小文件的大小
  byte[] b = new byte[1024];  //這個(gè)不解釋 如果看不懂 就去看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);  //我覺(jué)的這樣寫(xiě)比raf2.write(b);高明一些
    if(raf2.length() > fileLength)  //如果太大了就不在這個(gè)子文件寫(xiě)了 換下一個(gè)
     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();
 }
}

文件合并器就不寫(xiě)注釋了,因?yàn)檫@是一個(gè)逆過(guò)程。(懶癌附體)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java數(shù)據(jù)脫敏常用方法(3種)

    Java數(shù)據(jù)脫敏常用方法(3種)

    數(shù)據(jù)脫敏常用在電話號(hào)碼和身份證號(hào),本文主要介紹了Java數(shù)據(jù)脫敏常用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Java instanceof用法詳解及實(shí)例代碼

    Java instanceof用法詳解及實(shí)例代碼

    這篇文章主要介紹了Java instanceof用法詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • 基于Spring?Cache實(shí)現(xiàn)Caffeine+Redis二級(jí)緩存

    基于Spring?Cache實(shí)現(xiàn)Caffeine+Redis二級(jí)緩存

    本文主要介紹了基于Spring?Cache實(shí)現(xiàn)Caffeine+Redis二級(jí)緩存,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • ElasticSearch合理分配索引分片原理

    ElasticSearch合理分配索引分片原理

    這篇文章主要介紹了ElasticSearch合理分配索引分片原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • java實(shí)現(xiàn)學(xué)生選課系統(tǒng)

    java實(shí)現(xiàn)學(xué)生選課系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)學(xué)生選課系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • java制作仿微信視頻播放控件

    java制作仿微信視頻播放控件

    這篇文章主要介紹了java制作仿微信視頻播放控件的方法和代碼分享,控件繼承自SurfaceView,十分的實(shí)用,小伙伴們可以自由擴(kuò)展。
    2015-04-04
  • 關(guān)于Spring Cloud 本地屬性覆蓋的問(wèn)題

    關(guān)于Spring Cloud 本地屬性覆蓋的問(wèn)題

    這篇文章主要介紹了關(guān)于Spring Cloud 本地屬性覆蓋的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 詳解使用zxing庫(kù)生成QR-Code二維碼

    詳解使用zxing庫(kù)生成QR-Code二維碼

    這篇文章主要介紹了詳解使用zxing庫(kù)生成QR-Code二維碼的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列

    java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列

    這篇文章主要介紹了java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列的相關(guān)資料,這里對(duì)java中的棧和隊(duì)列都做出實(shí)現(xiàn)實(shí)例來(lái)幫助大家理解學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu),需要的朋友可以參考下
    2017-07-07
  • 淺談java中的一維數(shù)組、二維數(shù)組、三維數(shù)組、多維數(shù)組

    淺談java中的一維數(shù)組、二維數(shù)組、三維數(shù)組、多維數(shù)組

    下面小編就為大家?guī)?lái)一篇淺談java中的一維數(shù)組、二維數(shù)組、三維數(shù)組、多維數(shù)組。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05

最新評(píng)論