zoukankan
html css js c++ java
Net压缩文件流
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.IO.Compression; using System.IO; namespace gzipfile { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { //文件流 FileStream reader; reader = File.Open("D:\\ddd.txt", FileMode.Open); FileStream writer; writer = File.Create("D:\\ddd.gz"); //压缩相关的流 MemoryStream ms = new MemoryStream(); GZipStream zipStream = new GZipStream(ms, CompressionMode.Compress, true); //往压缩流中写数据 byte[] sourceBuffer = new byte[reader.Length]; reader.Read(sourceBuffer, 0, sourceBuffer.Length); zipStream.Write(sourceBuffer, 0, sourceBuffer.Length); //一定要在内存流读取之前关闭压缩流 zipStream.Close(); zipStream.Dispose(); //从内存流中读数据 ms.Position = 0; //注意,不要遗漏此句 byte[] destBuffer = new byte[ms.Length]; //ms.Read(destBuffer, 0, destBuffer.Length); byte[] header = new byte [10]; ms.Read(header, 0, 10); header[3] = 8; //表示包含文件名信息 byte[] fielContent = new byte[ms.Length -10] ; ms.Read(fielContent, 0, fielContent.Length); string strfilename = "widebright的文件.txt"; //指定初始文件名 //byte [] filename=System.Text.Encoding.Convert(System.Text.Encoding.Default, // // System.Text.Encoding.GetEncoding("ISO-8859-1"), // System.Text.Encoding.Default, // System.Text.Encoding.Default.GetBytes(strfilename)); byte[] filename = System.Text.Encoding.Default.GetBytes(strfilename); writer.Write(header, 0, header.Length); writer.Write(filename, 0, filename.Length); writer.WriteByte(0); //文件名以0 字节结束 writer.Write(fielContent, 0, fielContent.Length); //关闭并释放内存流 ms.Close(); ms.Dispose(); //关闭并释放文件流 writer.Close(); writer.Dispose(); reader.Close(); reader.Dispose(); } } }
查看全文
相关阅读:
POJ 1129 深搜&四色染图&模拟
POJ 1011 很经典的树枝拼凑的深度搜索
HDU 2564 词组缩写
Java中的split函数的用法
java中next和nextline的区别
简探this和super
再探Java中的继承加载顺序
Java面向接口编程小例子 2
Dos命令整理集(持续更新)
VMware WorkStation9.0虚拟机如何运行WINPE
原文地址:https://www.cnblogs.com/javawebsoa/p/2458115.html
最新文章
10-IOSCore
09-IOSCore
iOS图片拉伸技巧-李明杰分享
08-IOSCore
07-IOSCore
L2-006. 树的遍历
double等浮点数比较问题,eps
L2-010. 排座位
L2-009. 抢红包 结构体排序
L2-008 最长对称字串 以下标i展开
热门文章
L2-007 并查集处理&精度问题
打印Smith数 求质因数&判断质数&数位相加
L2-005. 集合相似度 数组&Sets容器
L2-003. 月饼 排序&贪心
PATL2-002. 链表去重。细心,格式
PAT天梯赛L2-001. 紧急救援 dijk经典最短路劲+点权最大+记录路径
个人赛&cf G题:The Tower of Evil 模拟&数学
hiho#1052 : 基因工程 字符串+找规律
#1050 :求多叉树中的的最长路
hiho #1038 : 01背包
Copyright © 2011-2022 走看看