库函数简单示例

本文介绍了静态库和动态库的基本概念及它们之间的主要区别。静态库在编译时会被链接到目标代码中,而动态库则在程序运行时被载入。文章还通过实例演示了如何创建和使用这两种类型的库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们常把一些常用的函数做成库的形式提供给其它程序使用,一般有动态库和静态库2种

静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库

动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在。

程序清单:

hello.h(见程序1)为该函数库的头文件。

hello.c(见程序2)是函数库的源程序,其中包含公用函数hello,该函数将在屏幕上输出"Hello XXX!"。

hello2.c(见程序3)是函数库的源程序,其中包含公用函数hello,该函数将在屏幕上输出"Hello2 XXX!"。

main.c(见程序4)为测试库文件的主程序,在主程序中调用了公用函数hello。

程序1

程序2

程序3

程序4

  • 编译程序成.o

gcc -c -fPIC hello.c

gcc -c -fPIC hello2.c

生成hello.o hello2.o

  • 生成静态库

ar cr libhello.a hello.o

ar cr libhello.a hello.o

生成libhello.a libhello2.a

  • 生成动态库

gcc --shared --fPIC -o libhello.so hello.o

gcc --shared --fPIC -o libhello2.so hello2.o

生成libhello.so libhello2.so

  • main使用静态库

gcc main.c libhello.a -o hello 或者gcc main.c -L. -lhello

./hello

Hello like!

删除libhello.a程序执行不受影响

  • main使用动态库

gcc main.c -L. -lhello -o hello

生成的hello ldd后可以看到需要libhello.so来运行

[like@mmdev1 so]$ ldd hello
        linux-vdso.so.1 =>  (0x00007fff0fb86000)
        libhello.so => /home/like/like_src/so/libhello.so (0x00007fca29ab2000)
        libc.so.6 => /lib64/libc.so.6 (0x0000003963200000)
        /lib64/ld-linux-x86-64.so.2 (0x0000003962e00000)

要将lib路径设置为可用

export LD_LIBRARY_PATH=/home/like/like_src/so/ 

./hello

Hello like!

删除libhello.so后程序不能执行

./hello: error while loading shared libraries: libhello.so: cannot open shared object file: No such file or directory

  • 库跟加载顺序有关

动态库

[like@mmdev1 so]$ gcc -o hello main.c -L. -lhello -lhello2
[like@mmdev1 so]$ ./hello
Hello like!
[like@mmdev1 so]$ gcc -o hello main.c -L. -lhello2 -lhello
[like@mmdev1 so]$ ./hello
Hello2 like!

静态库

[like@mmdev1 so]$ gcc -o hello main.c libhello2.a libhello.a      
[like@mmdev1 so]$ ./hello
Hello2 like!
[like@mmdev1 so]$ gcc -o hello main.c libhello.a libhello2.a
[like@mmdev1 so]$ ./hello
Hello like!

  • 动态静态同时存在时,会优先使用动态库 

目录下同时存在.a和.so,编译时

gcc -o hello main.c -L. -lhello

会默认使用动态库

[like@mmdev1 so]$ gcc -o hello main.c -L. -lhello
[like@mmdev1 so]$ ./hello
Hello like!
[like@mmdev1 so]$ ldd hello
        linux-vdso.so.1 =>  (0x00007fff0fb86000)
        libhello.so => /home/like/like_src/so/libhello.so (0x00007fca29ab2000)
        libc.so.6 => /lib64/libc.so.6 (0x0000003963200000)
        /lib64/ld-linux-x86-64.so.2 (0x0000003962e00000)

 

--the end

<think>好的,我现在需要回答用户关于zlib库函数使用示例的问题。首先,我得回想一下zlib库的基本信息。zlib是一个广泛使用的数据压缩库,提供DEFLATE算法的实现,常用于数据压缩和解压。用户可能想知道如何在代码中使用它,比如压缩和解压数据的步骤。 接下来,我应该考虑用户的需求层次。他们可能是一个开发者,想要在项目中使用zlib,所以需要具体的代码示例和步骤说明。用户可能需要从安装开始,到基本函数的调用,比如compress和uncompress,或者更高级的流式操作。 然后,我需要确保回答结构清晰,分步骤讲解。首先介绍安装,然后给出简单示例,再逐步深入。要注意使用正确的中文术语,并且代码部分需要用正确的格式,比如用反引号标出函数名和代码块。 同时,系统级指令要求数学表达式用$...$,但这里可能不太涉及数学公式,不过如果有涉及比如压缩比率计算,可能需要使用。但主要焦点是代码示例,所以可能不需要数学表达式。但需要确保LaTeX语法正确,如果有的话。 需要检查zlib的基本函数,比如compressBound,compress,uncompress等,并确保示例代码正确无误。例如,压缩后的数据需要记录实际大小,因为compress函数可能会使用比compressBound小的空间。解压时需要知道原始数据大小。 另外,可能需要提到流式处理,比如使用deflateInit,deflate,deflateEnd等函数来处理更大的数据块,这对于处理文件或网络流很有用。但用户可能首先需要简单示例,所以先展示compress和uncompress的基本用法,再提到更高级的方法。 要确保回答真实可靠,可能需要参考zlib的官方文档或可靠的教程。例如,compress函数返回Z_OK表示成功,处理错误情况也是重要的,但示例中可以简化,先展示成功情况,再提醒用户处理错误。 最后,结构要清晰,分点说明安装、示例、步骤解释、注意事项等。使用中文,避免术语混淆,必要时解释关键函数的作用和参数。</think>以下为zlib库使用示例的逐步说明: $\boxed{1. \text{安装与包含}}$ 首先需安装zlib库(Linux: `sudo apt-get install zlib1g-dev`),代码中需包含头文件: ```c #include <zlib.h> ``` $\boxed{2. \text{基础压缩示例}}$ 使用`compress()`函数压缩数据: ```c // 原始数据 char original[] = "Hello, this is a zlib compression test!"; uLong src_len = strlen(original) + 1; // 包含'\0' // 计算目标缓冲区大小 uLong dest_len = compressBound(src_len); Bytef* dest = (Bytef*)malloc(dest_len); // 执行压缩 int ret = compress(dest, &dest_len, (Bytef*)original, src_len); if (ret != Z_OK) { // 错误处理(zlib提供错误代码:Z_MEM_ERROR/Z_BUF_ERROR等) } ``` $\boxed{3. \text{解压示例}}$ 使用`uncompress()`恢复数据: ```c // 准备解压缓冲区(需已知原始数据长度) uLong uncompressed_len = src_len; Bytef* uncompressed = (Bytef*)malloc(uncompressed_len); // 执行解压 ret = uncompress(uncompressed, &uncompressed_len, dest, dest_len); if (ret == Z_OK) { printf("解压结果: %s\n", (char*)uncompressed); } ``` $\boxed{4. \text{流式压缩(高级)}}$ 处理大型数据时建议使用流式API: ```c z_stream strm; strm.zalloc = Z_NULL; strm.zfree = Z_NULL; strm.opaque = Z_NULL; deflateInit(&strm, Z_DEFAULT_COMPRESSION); // 初始化 // 循环调用deflate()逐块压缩数据 // 最后调用deflateEnd(&strm); ``` $\boxed{5. \text{关键函数说明}}$ - `compressBound()`: 计算压缩后最大可能长度 - `compress()/uncompress()`: 快速单次压缩/解压 - `deflateInit()/deflate()/deflateEnd()`: 流式压缩三件套 - `inflateInit()/inflate()/inflateEnd()`: 流式解压三件套 $\boxed{6. \text{注意事项}}$ - 解压时必须准确知道原始数据长度 - 流式操作需维护`z_stream`结构体状态 - 压缩级别可选`Z_NO_COMPRESSION`到`Z_BEST_COMPRESSION` - 建议检查所有函数返回值处理错误 完整示例代码可参考zlib官方示例:https://zlib.net/zlib_how.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值