嵌入式大杂烩周记 - 第 13 期

嵌入式大杂烩周记主要是一些实用项目学习分享,内容主要来源于我们之前收集的资料:

本期主角:lz4

在我们嵌入式开发中,通信中有些数据量较大的数据可以压缩之后再进行传输。

压缩算法有很多,常用的有如下几种:

  • lz4压缩算法
  • zstd压缩算法
  • xz压缩算法
  • gzip压缩算法

本次来介绍压缩界的速度之王——lz4压缩库。一些数据如:

lz4的使用

首先,从上面的链接中下载源码进行编译:

嵌入式物联网需要学的东西真的非常多,千万不要学错了路线和内容,导致工资要不上去!

无偿分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。

点击这里找小助理0元领取:嵌入式物联网学习资料(头条)




然后在源码根目录创建一个文件夹lz4_x86_lib:

编译lz4:

makemake install PREFIX=$(pwd)/lz4_x86_lib

得到:

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);

测试例子:

把字符串"12345678901234567890123456789012345678901234567890"进行lz4压缩,再解压,再把解压之后的内容打印出来。

编写测试代码:

左右滑动查看全部代码>>>

// 微信公众号:嵌入式大杂烩#include #include #include #include #include #include "lz4.h"long long get_sys_time_us(void){    long long time_us = 0;    struct timeval sys_current_time;    gettimeofday(&sys_current_time, NULL);    time_us = (long long)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
", src0, src0_size);    if (src0_size < max_dst0_size)    {        long long compress_start_time = get_sys_time_us();        dst0_compress_size = LZ4_compress_default(src0, dst0, src0_size, max_dst0_size);        long long compress_end_time = get_sys_time_us();        printf("after compress = %s
", dst0);        printf("compress_time = %lld us
", compress_end_time - compress_start_time);    } else    {        printf("compress error! src0_size >= max_dst0_size
");    }     // 解压    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
", src1);    }    else    {        printf("dst0_compress_size >= max_decompressed_size
");    }    if (compressed_size < max_decompressed_size)    {        long long decompress_start_time = get_sys_time_us();        dst1_decompress_size = LZ4_decompress_safe(src1, dst1, compressed_size, max_decompressed_size);        long long decompress_end_time = get_sys_time_us();        printf("after decompress = %s, bytes = %d
", dst1, dst1_decompress_size);        printf("decompress_time = %lld us
", decompress_end_time - decompress_start_time);    } else    {        printf("decompress error! compressed_size >= max_decompressed_size
");    }  return 0;}

编译运行:

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

更多实例可参照源码路径下的examples。

如果觉得文章有帮助,麻烦帮忙点赞、收藏、转发,谢谢!


原文链接:https://mp.weixin.qq.com/s/BZ8445umuGs3_bbEbdTRhg

转载自:嵌入式大杂烩

文章来源于杂烩君

原文链接:嵌入式大杂烩周记 | 第 13 期

本文来源网络,免费传达知识,版权归原作者所有。如涉及作品版权问题,请联系我进行删除。

发表评论
留言与评论(共有 0 条评论) “”
   
验证码:

相关文章

推荐文章