Optimized compression algorithm (on)

xiaoxiao2021-03-05  109

This is a compression algorithm code discussed in the 9CBS Forum.

Compared with WinRAR compare ZIP comparison, 255m file level = 0 is used in 24.98 seconds size 95.1mlevel = 255 hours 30.24 seconds size 91.6m

WinRAR is the fastest compression zip to use the 25.2 second size 58.6M standard RAR compression, I saw it, it is too slow, I haven't tried it, it is estimated that there will be a few minutes.

From the speed of view, it is basically flat. Although this algorithm is limited, it feels very clever, every time it is dynamic table, so that the software can be very small, and the resource is also very small. Very worth collecting!

'Test code form Option ExplicitPrivate WithEvents ObjZip As ClassZipPrivate BgTime As SinglePrivate Sub Command1_Click () BgTime Timer Command1.Enabled = False Command2.Enabled = False With ObjZip .InputFileName = Text1.Text .OutputFileName = Text2.Text .IsCompress = = true .CompressLevel = Val (Text4.Text) .BeginProcss End With Label1.Caption = Round (Timer - BgTime, 2) & "seconds" Command1.Enabled = true Command2.Enabled = TrueEnd SubPrivate Sub Command2_Click () BgTime = Timer Command1. Enabled = False Command2.Enabled = False With ObjZip .InputFileName = Text2.Text .OutputFileName = Text3.Text .IsCompress = False .BeginProcss End With Label1 = Round (Timer - BgTime, 2) & "seconds" Command1.Enabled = True Command2 .Enabled = truend subprivate sub command3_click () objzip.cancelprocss = truend subcancelprocss = true

Private Sub Form_Load () set objzip = new classzip command1.caption = "Compressed" Command2.caption = "Unzip" Command3.caption = "Interrupt" end submand

Private Sub Form_Unload (Cancel AS Integer) Set Objzip = Nothingend Sub

Private sub objzip_fileprogress (SNGPERCentage as single) Label1 = int (SNGPERCentage * 100) & "%" end sub

Private subjzip_procsserror (ErrorDescription as String) MsgBox ErrorDescriptionnd Neument and Properties, Methods, Methods, Events, Methods, Events, Methods, Events, Events

Option ExplicitPublic Event FileProgress (sngPercentage As Single) Public Event ProcssError (ErrorDescription As String) Private Type FileHeader HeaderTag As String * 3 HeaderSize As Integer Flag As Byte FileLength As Long Version As IntegerEnd TypePrivate mintCompressLevel As LongPrivate m_bEnableProcss As BooleanPrivate m_bCompress As BooleanPrivate m_strInputFileName As StringPrivate m_strOutputFileName As StringPrivate Const mcintWindowSize As Integer = & H1000Private Const mcintMaxMatchLen As Integer = 18Private Const mcintMinMatchLen As Integer = 3Private Const mcintNull As Long = & H1000Private Const mcstrSignature As String = "FMZ" Private Declare Sub CopyMemory Lib "Kernel32" Alias ​​"RtlMoveMemory" (pDest As Any, pSource As Any, ByVal dwLength As Long) Public Sub BeginProcss () If m_bCompress Then Compress Else Decompress End IfEnd SubPrivate Function LastError (ErrNo As Integer) As String Select Case ErrNo Case 1 LastError = "to be pressed The retracting file is not set or does not exist "Case 2 lasterror =" to be compressed file length is too small "case 3 lasterror =" to be compressed file has been compressed "Case 4 lasterror =" to be decompressed without setting or does not exist "Case 5 lasterror = "Case 254 lasterror =" Case 255 lasterror = "Unknown Error" end compressLevel () AS Integer CompressLevel () AS Integer CompressLevel () AS Integer CompressLevel () MintCompresslevel / 16nd PropertyPublic Property Let CompressLevel (Byval INTVALUE AS INTEGER) MintCompressLevel = INTVALUE * 16 IF MintCompressLevel <0 Then MintCompressLevel =

0nd PropertyPublic Property get iScompress () as boolean iScompress = m_bcompressend propertypublic property letyspress (Byval Bvalue as boolean) m_bcompress = BValueEnd Property

Public property let can CancelProcss (Byval Bvalue as Boolean) M_BenableProcss = NOT BVALUEEND Property

Public property Get InputFileName () AS String InputFileName = M_STRINPUTFILENAMEEND PROPERTY

Public Property Get OutputFileName () As String OutputFileName = m_strOutputFileNameEnd PropertyPublic Property Let OutputFileName (ByVal strValue As String) m_strOutputFileName = strValueEnd PropertyPublic Property Let InputFileName (ByVal strValue As String) m_strInputFileName = strValueEnd PropertyPrivate Sub Class_Terminate () m_bEnableProcss = FalseEnd Sub

转载请注明原文地址:https://www.9cbs.com/read-36734.html

New Post(0)