在Ubuntu系统中,使用GCC编译静态库(.a
文件)和动态库(.so
文件)的方法如下:
编写源代码:
假设你有两个源文件 libsource1.c
和 libsource2.c
。
编译源文件为对象文件:
gcc -c libsource1.c -o libsource1.o
gcc -c libsource2.c -o libsource2.o
创建静态库:
使用 ar
工具将对象文件打包成静态库。
ar rcs libmylib.a libsource1.o libsource2.o
使用静态库: 在编译主程序时,需要指定静态库的路径和名称。
gcc main.c -L/path/to/library -lmylib -o myprogram
其中 -L/path/to/library
指定库文件的路径,-lmylib
指定库的名称(去掉前缀 lib
和后缀 .a
)。
编写源代码:
假设你有两个源文件 libsource1.c
和 libsource2.c
。
编译源文件为位置无关代码(PIC)对象文件:
gcc -c -fPIC libsource1.c -o libsource1.o
gcc -c -fPIC libsource2.c -o libsource2.o
创建动态库:
使用 gcc
将对象文件链接成动态库。
gcc -shared -o libmylib.so libsource1.o libsource2.o
使用动态库: 在编译主程序时,需要指定动态库的路径和名称。
gcc main.c -L/path/to/library -lmylib -o myprogram
此外,还需要设置 LD_LIBRARY_PATH
环境变量,以便运行时能找到动态库。
export LD_LIBRARY_PATH=/path/to/library:$LD_LIBRARY_PATH
假设你有以下文件结构:
project/
├── libsource1.c
├── libsource2.c
├── main.c
└── Makefile
# 编译静态库
libmylib.a: libsource1.o libsource2.o
ar rcs $@ $^
libsource1.o: libsource1.c
gcc -c $< -o $@
libsource2.o: libsource2.c
gcc -c $< -o $@
# 编译动态库
libmylib.so: libsource1.o libsource2.o
gcc -fPIC -shared -o $@ $^
clean:
rm -f *.o *.a *.so
运行 make
命令将编译生成静态库和动态库,并清理中间文件。
通过以上步骤,你可以在Ubuntu系统中使用GCC编译静态库和动态库。