資料壓縮演算法LZO (C#)

來源:互聯網
上載者:User

LZO 是致力於解壓速度的一種資料壓縮演算法,LZO 是 Lempel-Ziv-Oberhumer 的縮寫。這個演算法是無損演算法,參考實現程式是安全執行緒的。

實現它的一個自由軟體工具是lzop。最初的庫是用 ANSI C 編寫、並且遵從 GNU通用公用許可證發布的。現在 LZO 有用於 Perl、Python 以及 Java 的各種版本。代碼著作權的所有者是 Markus F. X. J. Oberhumer。

LZO 庫實現了許多有下述特點的演算法:

* 解壓簡單,速度非常快。
* 解壓不需要記憶體。
* 壓縮相當地快。
* 壓縮需要 64 kB 的記憶體。
* 允許在壓縮部分以損失壓縮速度為代價提高壓縮率,解壓速度不會降低。
* 包括產生預先壓縮資料的壓縮層級,這樣可以得到相當有競爭力的壓縮比。
* 另外還有一個只需要 8 kB 記憶體的壓縮層級。
* 演算法是安全執行緒的。
* 演算法是無損的。

LZO 支援重複壓縮以及原地解壓。

LZO 是塊壓縮演算法——壓縮解壓成塊的資料。壓縮與解壓所用塊的大小必須一樣。

LZO 將資料區塊壓縮成匹配資料(滑動字典)與非匹配文字的序列。LZO 對於較長的匹配資料以及較長的非匹配文字序列有專門的處理,這樣對於高度冗餘的資料能夠取得很好的效果,並且對於不可壓縮的資料也能得到可以接受的效果。

當處理不可壓縮資料的時候,LZO 將每個 1024 位元組的輸入資料區塊擴充 16 位元組。

據報道 LZO 也在 AIX、 ConvexOS、IRIX、Mac OS、Palm OS、 PS1(PlayStation)、Solaris、SunOS、TOS (Atari ST) 以及 VxWorks 上得到實現。

參考文獻:

http://zh.wikipedia.org/wiki/LZO

源碼地址:

C: http://www.oberhumer.com/opensource/lzo/

c#:http://lzohelper.codeplex.com/

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.