当前位置:首页 > 嵌入式 > 嵌入式大杂烩
[导读]在我们嵌入式开发中,通信中有些数据量较大的数据可以压缩之后再进行传输。压缩算法有很多,常用的有如下几种:

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

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

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

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

lz4源码下载链接:

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

lz4的使用

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

然后在源码根目录创建一个文件夹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);

测试例子:

把字符串"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\n", 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\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) { 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\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");
    } return 0;
}

编译运行:

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

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

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

咱们下期见~

猜你喜欢:

嵌入式大杂烩周记 | 第 8 期 AMetal

嵌入式大杂烩周记 | 第 7 期 zlog

嵌入式大杂烩周记 | 第 6 期 FlexibleButton

嵌入式大杂烩周记 | 第 5 期 smartlink

嵌入式大杂烩周记 | 第 4 期 cola_os

嵌入式大杂烩周记 | 第 3 期 sys/queue.h

嵌入式大杂烩周记 | 第 2 期 llgui

嵌入式大杂烩周记 | 第 1 期 gear-lib

在公众号聊天界面回复1024,可获取嵌入式资源;回复 m ,可查看文章汇总。

点击阅读原文,查看更多分享。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

本届年会将在上海(11月13-14日)、北京(11月19-20日)和深圳(11月27-28日)举行,面向嵌入式设计工程师推出25门技术课程

关键字: 嵌入式 MCU 模拟

上海2025年9月5日 /美通社/ -- 由纽伦堡会展(上海)有限公司举办的上海国际嵌入式会议将于 2025 年 10 月 16-17 日在上海世博展览馆举办。 此次会议将由三个版块组成:嵌入式技术会议、汽...

关键字: 嵌入式 CE CHINA EMBEDDED

从外部看,电子系统仿佛一个统一的学科或设备,各组成部分协同工作,浑然一体。然而揭开表象,其内在却是另一番景象:一个碎片化、多层次的世界——其中每一层都独立且复杂,衍生出各自特有的工具、专家、工作流程,甚至哲学体系。

关键字: 嵌入式 电子系统 半导体

8位单片机在嵌入式设计领域已经成为半个多世纪以来的主流选择。尽管嵌入式系统市场日益复杂,8位单片机依然不断发展,积极应对新的挑战和系统需求。如今,Microchip推出的8位PIC®和AVR®单片机系列,配备了先进的独立...

关键字: 单片机 嵌入式 CPU

深圳2025年8月28日 /美通社/ -- 8月26日,2025 ELEXCON深圳国际电子展盛大启幕。本届大会以"All for AI"为主题,深圳市德...

关键字: AI 工业级 SSD 嵌入式

深圳2025年8月26日 /美通社/ -- 8月26日,由博闻创意会展主办的 第22届深圳国际电子展暨嵌入式展(elexcon2025)在深圳(福田)会展中心隆重开幕。 作为中国电子与嵌入式技术领域的专业大展,本届展会...

关键字: 嵌入式 电子 高通 AI

模块化设计作为一种将系统拆分为独立、可复用组件的方法,能够在低代码平台中实现功能的灵活组合,并最大限度地提升系统性能。本文将探讨如何通过模块化设计,使得低代码平台既能快速适应变化,又能保持高效稳定的运行。

关键字: 模块化设计 嵌入式

CPU亲和度通过限制进程或线程可以运行的CPU核心集合,使得它们只能在指定的CPU核心上执行。这可以减少CPU缓存的失效次数,提高缓存命中率,从而提升系统性能。

关键字: Linux 嵌入式

加密算法分对称加密和非对称算法,其中对称加密算法的加密与解密密钥相同,非对称加密算法的加密密钥与解密密钥不同,此外,还有一类不需要密钥的散列算法。

关键字: 算法 嵌入式

从本质上讲,算法是一种有条不紊、分步骤解决问题或完成任务的方法。无论是简单的数字相加公式,还是复杂的机器学习协议,算法都是软件应用的基础,确保任务能够高效有效地执行。

关键字: 算法 嵌入式
关闭