项目迭代开发手记--文件分割存储用例的实现过程(2)
2006-02-04 13:54:26 来源:WEB开发网核心提示:项目迭代开发手记--文件分割存储用例的实现过程(2) 在第二天早上的开发中我们扩展了第一天迭代开发的用例,我们考虑增加了压缩流的功能,项目迭代开发手记--文件分割存储用例的实现过程(2),减少数据的存储负担,迭代2:用例:对向数据库提交的二进制流进行压缩;那么从数据库提取的时候要进行解压操作,提交了一个可以使用的版本,
项目迭代开发手记--文件分割存储用例的实现过程(2)
在第二天早上的开发中我们扩展了第一天迭代开发的用例,我们考虑增加了压缩流的功能,减少数据的存储负担。
迭代2:
用例:对向数据库提交的二进制流进行压缩;那么从数据库提取的时候要进行解压操作,以获得原始图档数据。
通过查询资料我们找到Delphi的ZLib库支持对字节流的压缩和解压缩功能,这样我们只要使用该类的TComPRessionStream和TDecompressionStream就可以实现压缩和解压缩功能,为了更好的封装这种过程方便项目组重用,我们对压缩和解压缩功能进行了封装。
我们定义了TLoadBinaryDataToDB类来封装压缩和解压的功能,以便于使用。
类定义了procedure LoadFile(fileFullName: string);来装载图档文件,同时压缩装载的流。
procedure TLoadBinaryDataToDB.LoadFile(fileFullName: string); begin FStream.LoadFromFile(fileFullName); CompressStream; //对装载的流进行压缩 end; procedure TLoadBinaryDataToDB.CompressStream; var iSize: Integer; lDestStream : TMemoryStream; lCompressionStream : TCompressionStream; begin lDestStream := TMemoryStream.Create; lCompressionStream := TCompressionStream.Create(clMax,lDestStream); try iSize := FStream.Size; //获得图像流的原始尺寸 FStream.SaveToStream(lCompressionStream); //将原始图像流进行压缩, //lDestStream中保存着压缩后的图像流 lCompressionStream.Free; FStream.Clear; FStream.WriteBuffer(iSize, SizeOf(iSize)); FStream.CopyFrom(lDestStream, 0);//写入经过压缩的图像流 finally lDestStream.Free end; end; 这样装载后的流就被压缩了,向数据库提交的流就是进过压缩过的。 … LoadBinaryDataToDB.LoadFile(lFullFileName); ClientDataSet1.Append; ClientDataSet1.FieldByName('F_ID').Value := 2; ClientDataSet1.FieldByName('F_NAME').Value := lFileFullName; (ClientDataSet1.FieldByName('F_BINARY_DATA')
as TBlobField).LoadFromStream(LoadBinaryDataToDB.FileStream); ClientDataSet1.Post; 类还封装了另一个函数 procedure UnCompressStream(var stream :TMemoryStream)该函数实现了对压缩流的逆向解压过程。 procedure TLoadBinaryDataToDB.UnCompressStream(var stream :TMemoryStream); var DecompressionStream: TDecompressionStream; Buffer: PChar; Count: Integer; begin stream.ReadBuffer(Count, SizeOf(Count)); GetMem(Buffer, Count); DecompressionStream := TDecompressionStream.Create(stream); try DecompressionStream.ReadBuffer(Buffer^, Count);//将被压缩的图像流解压缩,然后存入 Buffer内存块中 stream.Clear; stream.WriteBuffer(Buffer^, Count); //将原始图像流保存至 stream流中 stream.Position := 0; finally FreeMem(Buffer); // 释放内存 end; end; 通过下面这样的调用我们就可以还原图档数据。 (ClientDataSet1.FieldByName('F_BINARY_DATA')
as TBlobField). SaveToStream(lBlobStream); LoadBinaryDataToDB.UnCompressStream(lBlobStream); //lBlobStream 为解压后的二进制字节流了 对了类进行这样的封装很好的实现了压缩和解压代码的重用,开发人员只要创建该类的对象就可以对流进行相应的处理。 到中午的时候我们完成了该类的实现,提交了一个可以使用的版本,由于对该项技术的不熟悉过程中我们还是走了不少弯路,查找了不少技术文档。
类定义了procedure LoadFile(fileFullName: string);来装载图档文件,同时压缩装载的流。
procedure TLoadBinaryDataToDB.LoadFile(fileFullName: string); begin FStream.LoadFromFile(fileFullName); CompressStream; //对装载的流进行压缩 end; procedure TLoadBinaryDataToDB.CompressStream; var iSize: Integer; lDestStream : TMemoryStream; lCompressionStream : TCompressionStream; begin lDestStream := TMemoryStream.Create; lCompressionStream := TCompressionStream.Create(clMax,lDestStream); try iSize := FStream.Size; //获得图像流的原始尺寸 FStream.SaveToStream(lCompressionStream); //将原始图像流进行压缩, //lDestStream中保存着压缩后的图像流 lCompressionStream.Free; FStream.Clear; FStream.WriteBuffer(iSize, SizeOf(iSize)); FStream.CopyFrom(lDestStream, 0);//写入经过压缩的图像流 finally lDestStream.Free end; end; 这样装载后的流就被压缩了,向数据库提交的流就是进过压缩过的。 … LoadBinaryDataToDB.LoadFile(lFullFileName); ClientDataSet1.Append; ClientDataSet1.FieldByName('F_ID').Value := 2; ClientDataSet1.FieldByName('F_NAME').Value := lFileFullName; (ClientDataSet1.FieldByName('F_BINARY_DATA')
as TBlobField).LoadFromStream(LoadBinaryDataToDB.FileStream); ClientDataSet1.Post; 类还封装了另一个函数 procedure UnCompressStream(var stream :TMemoryStream)该函数实现了对压缩流的逆向解压过程。 procedure TLoadBinaryDataToDB.UnCompressStream(var stream :TMemoryStream); var DecompressionStream: TDecompressionStream; Buffer: PChar; Count: Integer; begin stream.ReadBuffer(Count, SizeOf(Count)); GetMem(Buffer, Count); DecompressionStream := TDecompressionStream.Create(stream); try DecompressionStream.ReadBuffer(Buffer^, Count);//将被压缩的图像流解压缩,然后存入 Buffer内存块中 stream.Clear; stream.WriteBuffer(Buffer^, Count); //将原始图像流保存至 stream流中 stream.Position := 0; finally FreeMem(Buffer); // 释放内存 end; end; 通过下面这样的调用我们就可以还原图档数据。 (ClientDataSet1.FieldByName('F_BINARY_DATA')
as TBlobField). SaveToStream(lBlobStream); LoadBinaryDataToDB.UnCompressStream(lBlobStream); //lBlobStream 为解压后的二进制字节流了 对了类进行这样的封装很好的实现了压缩和解压代码的重用,开发人员只要创建该类的对象就可以对流进行相应的处理。 到中午的时候我们完成了该类的实现,提交了一个可以使用的版本,由于对该项技术的不熟悉过程中我们还是走了不少弯路,查找了不少技术文档。
- ››开发Android 日历教程
- ››开发学院总结 Win 8实用技巧大全
- ››开发学院原创教程:把win8的IE10放桌面上方法(非...
- ››开发者眼中的Windows Phone和Android
- ››开发学院教你用SQL 语句最快速清空MySQL 数据表的...
- ››开发一个自己的HTML在线编辑器(一)
- ››开发一个自己的HTML在线编辑器(二)
- ››开发者在App Store上赚的钱比在Android Market上多...
- ››开发者应深入学习的10个Android开源应用项目
- ››开发移动 Web Ajax 应用
- ››开发者眼中的iPhone与Android
- ››迭代开发:WebSphere adapters 7.0 让您更灵活的开...
更多精彩
赞助商链接