性无码一区二区三区在线观看,少妇被爽到高潮在线观看,午夜精品一区二区三区,无码中文字幕人妻在线一区二区三区,无码精品国产一区二区三区免费

嵌入式應(yīng)用中,有哪些好用的壓縮庫?

在我們嵌入式開發(fā)中,通信中有些數(shù)據(jù)量較大的數(shù)據(jù)可以壓縮之后再進行傳輸。

壓縮算法有很多,常用的有如下幾種:

  • lz4壓縮算法
  • zstd壓縮算法
  • xz壓縮算法
  • gzip壓縮算法

本次來介紹壓縮界的速度之王——lz4壓縮庫。一些數(shù)據(jù)如:

lz4源碼下載鏈接:

http://security.ubuntu.com/ubuntu/pool/main/l/lz4/

lz4的使用

首先,從上面的鏈接中下載源碼進行編譯:

然后在源碼根目錄創(chuàng)建一個文件夾lz4_x86_lib:

編譯lz4:

make
make install PREFIX=$(pwd)/lz4_x86_lib

得到:

lz4庫交叉編譯可參照:https://blog.csdn.net/nh5431313/article/details/106387168

lz4庫有幾套壓縮、解壓接口,我們使用最簡單的接口:

int LZ4_compress_default(const char* source, char* dest, int sourceSize, int maxDestSize);
int LZ4_decompress_safe (const char* source, char* dest, int compressedSize, int maxDecompressedSize);

測試?yán)樱?/span>

把字符串"12345678901234567890123456789012345678901234567890"進行l(wèi)z4壓縮,再解壓,再把解壓之后的內(nèi)容打印出來。

編寫測試代碼:

// 微信公眾號:嵌入式大雜燴
#include 
#include 
#include 
#include 
#include 
#include "lz4.h"

long long get_sys_time_us(void)
{
    longlong time_us = 0;
    struct timeval sys_current_time;

    gettimeofday(&sys_current_time, NULL);
    time_us = (longlong)sys_current_time.tv_sec*1000000 + sys_current_time.tv_usec;

    return time_us;
}

int main(int arc, char *argv[])
{
    // 壓縮
    char *src0 = "12345678901234567890123456789012345678901234567890";
    char dst0[64] = {0};
int src0_size = strlen(src0) + 1;
    int max_dst0_size = sizeof(dst0);
    int dst0_compress_size = 0;

printf("before compress = %s, bytes = %d\n", src0, src0_size);
    if (src0_size < max_dst0_size)
    {
        longlong compress_start_time = get_sys_time_us();
        dst0_compress_size = LZ4_compress_default(src0, dst0, src0_size, max_dst0_size);
        longlong compress_end_time = get_sys_time_us();
        printf("after compress = %s\n", dst0);
        printf("compress_time = %lld us\n", compress_end_time - compress_start_time);
    }
else
    {
        printf("compress error! src0_size >= max_dst0_size\n");
    }

    // 解壓
    char src1[64] = {0};
    char dst1[64] = {0};
    int compressed_size = dst0_compress_size;
    int max_decompressed_size = sizeof(dst1);
    int dst1_decompress_size = 0;

    if (dst0_compress_size < max_decompressed_size)
    {
        memcpy(src1, dst0, dst0_compress_size);
        printf("before decompress = %s\n", src1);
    }
    else
    {
        printf("dst0_compress_size >= max_decompressed_size\n");
    }

    if (compressed_size < max_decompressed_size)
    {
        longlong decompress_start_time = get_sys_time_us();
        dst1_decompress_size = LZ4_decompress_safe(src1, dst1, compressed_size, max_decompressed_size);
        longlong decompress_end_time = get_sys_time_us();
        printf("after decompress = %s, bytes = %d\n", dst1, dst1_decompress_size);
        printf("decompress_time = %lld us\n", decompress_end_time - decompress_start_time);
    }
else
    {
        printf("decompress error! compressed_size >= max_decompressed_size\n");
    }

return0;
}

編譯運行:

gcc -o lz4_test lz4_test.c -Llz4_x86_lib/lib -Ilz4_x86_lib/include -llz4
./lz4_test

聲明:本內(nèi)容為作者獨立觀點,不代表電子星球立場。未經(jīng)允許不得轉(zhuǎn)載。授權(quán)事宜與稿件投訴,請聯(lián)系:editor@netbroad.com
覺得內(nèi)容不錯的朋友,別忘了一鍵三連哦!
贊 1
收藏 1
關(guān)注 30
成為作者 賺取收益
全部留言
0/200
成為第一個和作者交流的人吧