国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

.Net實現合并文件的具體方法

來源:懂視網 責編:小采 時間:2020-11-27 22:40:39
文檔

.Net實現合并文件的具體方法

.Net實現合并文件的具體方法: 以上列表中的文件并不是來自于某個文件夾中的所有jpg文件,而是來自于 這個文件。將多個文件合并為一個文件在許多應用領域都十分有用。親自實現這樣一個程序一定不但過癮且在許多時候可以幫助我們構建更高效的程序。這里我做了一個方案例分享給大家。由于合
推薦度:
導讀.Net實現合并文件的具體方法: 以上列表中的文件并不是來自于某個文件夾中的所有jpg文件,而是來自于 這個文件。將多個文件合并為一個文件在許多應用領域都十分有用。親自實現這樣一個程序一定不但過癮且在許多時候可以幫助我們構建更高效的程序。這里我做了一個方案例分享給大家。由于合

以上列表中的文件并不是來自于某個文件夾中的所有jpg文件,而是來自于

這個文件。
將多個文件合并為一個文件在許多應用領域都十分有用。親自實現這樣一個程序一定不但過癮且在許多時候可以幫助我們構建更高效的程序。這里我做了一個方案例分享給大家。
由于合并后的文件就像一個包裹,所以下文中都把這樣的文件稱為“包文件”
主構思:
要把多個文件合并成一個包文件,還要可以區分其中的某個文件并提取出來。我們需要知道文件的名稱和這個文件在包文件中的位置及長度,也就是所謂的地址偏移。
由于包文件常常會比較大,所以不應該讓它的內容常駐于內存,只應該需要某部分的時候再從包文件中提取。
我是這樣做的:

一個管理器類,提供一些外圍的方法
_pathList用于存放要添加到包文件的文件路徑,通過調用AddSourceFile()方法添加
_pf 是具體的包文件,通過LoadPackFile() 生成實例,通過CurrentPackFile屬性返回
Build方法用于生成包文件

PackFile類作為PackFileManager的嵌套類,它提供包文件的屬性和施工細節。
好了,我們先來看看PackFileManager.Build()方法
代碼如下:
           public void Build(string path)
        {
            using (FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write))
            {
                BinaryWriter bw = new BinaryWriter(fs);
                bw.Write("PackFile");
                bw.Write(this._pathList.Count);
                foreach (string f in this._pathList)
                {
                    FileInfo fi = new FileInfo(f);
                    bw.Write(fi.Length);
                    fi = null;
                }
                foreach (string f in this._pathList)
                {
                    bw.Write(Path.GetFileName(f));
                }
                foreach (string f in this._pathList)
                {
                    bw.Write(File.ReadAllBytes(f));
                    bw.Flush();
                }
            }
        }

1. 先寫個“PackFile”字符串到文件頭
2. 把以Int32為類型的,要輸出到包文件中的文件數量寫入
3. 把以long為類型的,要輸出到包文件中的每個文件的長度寫入。
4. 再把每個文件名寫入
5. 最后寫入每個文件的實體內容。
由于在寫或讀時不頻繁在Write方法或ReadXXX方法的不同版本間頻繁切換,所以我想這樣組織文件結構可以更高效一些。

疑問來了。在寫入文件名的時候,我們使用bw.Write(Path.GetFileName(f));
調用了BinaryWriter.Write(string value),傳入的是字符串,那么在讀取的時候要調用BinaryReader.ReadString()。這時它是如何區分兩個字符串邊界的。還好,Write方法會先將字符串長度作為一個四字節無符號整數寫入,于是在用BinaryReader.ReadString()的時候它會根據這個值來讀取特定長度的值,并理解為字符串。
這里列出幾個重要方法:
代碼如下:
PackFileManager的LoadPackFile方法
       public void LoadPackFile(string path)
        {
            if (!File.Exists(path))
            {
                throw new FileNotFoundException(path);
            }
            if (_pf != null)
            {
                _pf.Close();
                _pf = null;
            }
            FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read);
            BinaryReader br = new BinaryReader(fs);
            if (br.ReadString() != "PackFile")
            {
                throw new InvalidCoalescentFileException("該文件不是有效的包文件");
            }
            this._pf = new PackFile(fs,br);
        }

此時,我們在生成時寫入的字符串"PackFile" 就有了明確的功能
PackFile的構造函數
代碼如下:
        internal PackFile(FileStream srcFile,BinaryReader br)
            {
                this._sourceFile = srcFile;
                _br = br;
                this._fileCount = _br.ReadInt32();//取文件數
                for (int i = 1; i <= _fileCount; i++)
                {
                    this._fileLengthList.Add(_br.ReadInt64());
                }
                for (int i = 1; i <= _fileCount; i++)
                {
                    this._shortNameList.Add(_br.ReadString());
                }
                this._contentStartPos = _sourceFile.Position;//設置實體文件總起始位置
            }
 
PackFile.GetBytes()
代碼如下:
            public byte[] GetBytes(int index)
            {
                long startPos = this._contentStartPos;
                for (int i = 0; i < index; i++)
                {
                    startPos += this._fileLengthList[i];
                }
                _sourceFile.Position = startPos; //設置某文件內容的起始位置
                return _br.ReadBytes((int)_fileLengthList[index]);
            }

這只是一個草案,我們還可以加入壓縮、或是像ZIP文件那樣的嵌套文件夾功能,改進后的代碼別忘與我分享哦。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

.Net實現合并文件的具體方法

.Net實現合并文件的具體方法: 以上列表中的文件并不是來自于某個文件夾中的所有jpg文件,而是來自于 這個文件。將多個文件合并為一個文件在許多應用領域都十分有用。親自實現這樣一個程序一定不但過癮且在許多時候可以幫助我們構建更高效的程序。這里我做了一個方案例分享給大家。由于合
推薦度:
標簽: 文件 方法 實現
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲一区二区三区中文字幕 | 亚洲欧美日韩中文无线码 | 国产高清一区二区三区视频 | 日本1区2区 | 国产免费一区二区三区免费视频 | 欧美色图亚洲自拍 | 亚洲欧美国产日本 | 在线国产视频观看 | 久久精品成人国产午夜 | 欧美一区二区三区在线播放 | 在线精品欧美日韩 | www.亚洲欧美 | 国内精品99 | 国产中文久久精品 | 亚洲一区二区三区在线播放 | 亚洲欧洲另类 | xxx色xxx性| 欧美日韩a | 日韩精品在线看 | 欧美色人| 国产精品视频播放 | 手机看片91精品一区 | 日韩精品在线第一页 | 国产亚洲欧美日韩俺去了 | 精品国产日韩亚洲一区二区 | 国产免费播放 | 国产成人综合久久精品尤物 | 免费精品国产 | 亚洲精品免费在线观看 | 韩日视频在线 | 日本一二三区高清 | 日韩a无v码在线播放免费 | 久久这里只有精品国产 | 综合亚洲一区二区三区 | 欧美日韩视频一区二区三区 | 亚洲欧洲一二三区 | 欧美视频日韩专区午夜 | 久久亚洲精品国产亚洲老地址 | 最新国产在线视频 | 国产一区91| 欧美在线一区二区三区不卡 |