這篇文章將為大家詳細(xì)講解有關(guān)怎么在java中使用IO流將一個(gè)文件拆分為多個(gè)子文件,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
專注于為中小企業(yè)提供做網(wǎng)站、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)莫力達(dá)免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千多家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。基本思路:
如果有一個(gè)大文件,指定分割大小后(比如:按1M切割)
step 1:
先根據(jù)原始文件大小、分割大小,算出最終分割的小文件數(shù)N
step 2:
在磁盤(pán)上創(chuàng)建這N個(gè)小文件
step 3:
開(kāi)多個(gè)線程(線程數(shù)=分割文件數(shù)),每個(gè)線程里,利用RandomAccessFile的seek功能,將讀取指針定位到原文件里每一段的段首位置,然后向后讀取指定大小(即:分割塊大?。罱K寫(xiě)入對(duì)應(yīng)的分割文件,因?yàn)槎嗑€程并行處理,各寫(xiě)各的小文件,速度相對(duì)還是比較快的。
下面代碼是將一個(gè)文件拆分為多個(gè)子文件,每個(gè)大小是100K
package testIO; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.util.Arrays; public class subStream { public static void main(String[] args) { //先將源文件讀取到內(nèi)存中 int eachSize=100*1024; File srcFile =new File("F:/test/test.txt"); //創(chuàng)建一個(gè)文件對(duì)象 splitFile(srcFile,eachSize); } public static void splitFile(File srcFile,int eachSize){ //判斷文件是否符合拆分要求 if(srcFile.length()==0){ throw new RuntimeException("文件不符合拆分要求"); } byte[] fileContent= new byte[(int) srcFile.length()]; try { //將文件內(nèi)容讀取到內(nèi)存中 FileInputStream fis=new FileInputStream(srcFile); fis.read(fileContent); fis.close(); } catch (Exception e) { e.printStackTrace(); } //計(jì)算要次要拆分為多少份 int fileNumber; if(fileContent.length%eachSize==0){ fileNumber = fileContent.length/eachSize; } else{ fileNumber = fileContent.length/eachSize+1; } for (int i=0;i關(guān)于怎么在java中使用IO流將一個(gè)文件拆分為多個(gè)子文件就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
本文標(biāo)題:怎么在java中使用IO流將一個(gè)文件拆分為多個(gè)子文件-創(chuàng)新互聯(lián)
分享地址:http://weahome.cn/article/dihpsp.html