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

java實現(xiàn)文件歸檔和還原

 更新時間:2019年09月26日 08:31:04   作者:binSama  
這篇文章主要為大家詳細介紹了java實現(xiàn)文件歸檔和還原,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java實現(xiàn)文件歸檔和還原的具體代碼,供大家參考,具體內容如下

基本思路: 

文件歸檔,換句話就是把多個文件的字節(jié)存到一個文件中。為此我們必須定義存儲格式,才能從包中把文件重新抽出來。

文件由文件名和內容組成。要想完整的還原文件,我們必須同時存下這兩個東西,而文件名和內容的字節(jié)大小我們都是不知道的,為此我們必須要用固定大小的空間存儲它們的大小。

存儲格式

代碼實現(xiàn)

因為文件內容大小是4個字節(jié)(也就是int型),我們要把它存到文件,就要轉化成字節(jié)數(shù)組。我們規(guī)定低位靠前,高位靠后。按照這種格式封裝轉換操作與一個基礎類DataUtil中。

DataUtil代碼

package util;

public class DataUtil {
 public static byte[] int2bytes(int src) {
 byte[] rt = new byte[4];
 for(int i=0; i<4; ++i) {
 rt[i] = (byte)(src>>(i*8));
 }
 return rt;
 }
 public static int bytes2int(byte[] src) {
 int rt = 0;
 for(int i=0; i<4; ++i) {
 rt |= (src[i]&0xFF)<<(i*8);
 //字節(jié)在進行移位運算時,首先會被轉換成int類型,
 //此時若字節(jié)的符號位為1,它前面就會補全1,比如:
 //0x80在byte類型時是-128,而轉換成int,它的值還是
 //-128,即0xffffff80,而我們移位運算想要的是
 //0x00000080,即前面補全0,跟我們拆時一致。為此,
 //我們讓它與0xFF相與,從0xffffff80變?yōu)?x00000080。
 }
 return rt;
 }
}

歸檔類

package wfb.binSama;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;

import util.DataUtil;

/**
 * @author binSama
 */
public class Archive {
 
 public static void archive(File[] srcs,File tar) {//歸檔
 try {
 FileOutputStream fos = new FileOutputStream(tar);
 for(int i=0; i<srcs.length; ++i) {
 //獲得文件名
 byte[] fileName = srcs[i].getName().getBytes();
 //獲得文件名長度
 byte fileNameLen = (byte)fileName.length;
 //獲得文件內容
 FileInputStream fis = new FileInputStream(srcs[i]);
 ByteArrayOutputStream baos = new ByteArrayOutputStream();
 int len = -1;
 byte[] buf = new byte[1024];
 while((len = fis.read(buf)) != -1) {
  baos.write(buf, 0, len);
 }
 baos.close();
 fis.close();
 byte[] fileContent = baos.toByteArray();
 //獲得文件內容長度
 byte[] fileContentLen = DataUtil.int2bytes(fileContent.length);
 //寫入
 fos.write(fileNameLen);
 fos.write(fileName);
 fos.write(fileContentLen);
 fos.write(fileContent);
 }
 fos.close();
 } catch (Exception e) {
 e.printStackTrace();
 }
 }
 
 public static void unArchive(File src) {//解檔到當前文件夾
 try {
 FileInputStream fis = new FileInputStream(src);
 int fileNameLen = -1;
 while((fileNameLen = fis.read()) != -1){
 byte[] byteFileName = new byte[fileNameLen];
 fis.read(byteFileName);
 String fileName = src.getParent() +"\\"+ new String(byteFileName);
 FileOutputStream fos = new FileOutputStream(fileName);
 byte[] byteFileContentLen = new byte[4];
 fis.read(byteFileContentLen);
 int fileContentLen = DataUtil.bytes2int(byteFileContentLen);
 int divisorFileContentLen = fileContentLen / 1024;
 int remainderFileContentLen = fileContentLen % 1024;
 ByteArrayOutputStream baos = new ByteArrayOutputStream();
 byte[] divisorBuf = new byte[1024];
 for(int i=0; i<divisorFileContentLen; ++i) {
  fis.read(divisorBuf);
  baos.write(divisorBuf);
 }
 byte[] remainderBuf = new byte[remainderFileContentLen];
 fis.read(remainderBuf);
 baos.write(remainderBuf);
 baos.close();
 byte[] fileContent = baos.toByteArray();
 fos.write(fileContent);
 }
 fis.close();
 } catch (Exception e) {
 e.printStackTrace();
 }
 }
}

測試:

package wfb.binSama;

import java.io.File;

public class Test {
 @org.junit.Test
 public void test() {
 File[] files = new File[3];
 files[0] = new File("E:\\waster\\Archiver1\\1.txt");
 files[1] = new File("E:\\waster\\Archiver1\\2.png");
 files[2] = new File("E:\\waster\\Archiver1\\3.txt");
 File bsm = new File("E:\\waster\\Archiver2\\archive.bsm");
 Archive.archive(files, bsm);
 Archive.unArchive(bsm);
 }
 
}

現(xiàn)象

成功在E:\waster\Archiver2文件夾生成了archive.bsm歸檔文件,并解檔出1.txt 2.png 3.txt三個文件。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關文章

  • Java如何求交集、并集、差集

    Java如何求交集、并集、差集

    這篇文章主要介紹了Java如何求交集、并集、差集問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 基于log4j2.properties踩坑與填坑

    基于log4j2.properties踩坑與填坑

    這篇文章主要介紹了log4j2.properties踩坑與填坑方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • java微信紅包實現(xiàn)算法

    java微信紅包實現(xiàn)算法

    這篇文章主要為大家詳細介紹了java微信紅包實現(xiàn)算法,列出紅包的核心算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • SpringMVC整合websocket實現(xiàn)消息推送及觸發(fā)功能

    SpringMVC整合websocket實現(xiàn)消息推送及觸發(fā)功能

    這篇文章主要為大家詳細介紹了SpringMVC整合websocket實現(xiàn)消息推送及觸發(fā)功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • java中注解的原理解析

    java中注解的原理解析

    這篇文章主要介紹了java中注解的原理解析,java 注解又稱 Java 標注,是 JDK5.0 引入的一種注釋機制,可以理解為為某個東西,打個標記的記號,等要使用這個注解時,可以通過反射獲取標注里面的內容,需要的朋友可以參考下
    2023-10-10
  • 關于Java利用反射實現(xiàn)動態(tài)運行一行或多行代碼

    關于Java利用反射實現(xiàn)動態(tài)運行一行或多行代碼

    這篇文章主要介紹了關于Java利用反射實現(xiàn)動態(tài)運行一行或多行代碼,借鑒了別人的方法和書上的內容,最后將題目完成了,和大家一起分享以下解決方法,需要的朋友可以參考下
    2023-04-04
  • JavaMail郵件發(fā)送機制詳解

    JavaMail郵件發(fā)送機制詳解

    這篇文章主要介紹了JavaMail郵件發(fā)送機制詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • elasticsearch如何根據(jù)條件刪除數(shù)據(jù)

    elasticsearch如何根據(jù)條件刪除數(shù)據(jù)

    Elasticsearch是一個基于Apache Lucene?的開源搜索引擎,無論在開源還是專有領域,Lucene 可以被認為是迄今為止最先進、性能最好的、功能最全的搜索引擎庫,這篇文章主要介紹了elasticsearch如何根據(jù)條件刪除數(shù)據(jù),需要的朋友可以參考下
    2023-03-03
  • springboot swagger 接口文檔分組展示功能實現(xiàn)

    springboot swagger 接口文檔分組展示功能實現(xiàn)

    這篇文章主要介紹了springboot swagger 接口文檔分組展示功能實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • java音頻播放示例分享(java如何播放音頻)

    java音頻播放示例分享(java如何播放音頻)

    java如何播放音頻?下面的代碼就介紹了java音頻播放示例,需要的朋友可以參考下
    2014-04-04

最新評論