您的位置:首页 > 运维架构 > Linux

LINUX 动态库编译和使用的注意事项

2017-11-24 09:42 387 查看

动态库编译

下面是动态库编译的脚本编写

$(DLLTARGET): $(LIBOBJS)
$(CC) -shared -fPIC $(CXXFLAGS) -Wl,--whole-archive $(LDLIBS) $(LIBOBJS) -Wl,-no-whole-archive -Wl,--retain-symbols-file=exports.map -Wl,--version-script=exports.map -o $@


几点注意:

1. 对于引用的静态库,通过-Wl,–whole-archive命令嵌入进来,后面运行就不依赖于这些静态库了。

2. LINUX默认导出所有符号,这个容易引起符号冲突。可以通过-fvisibility=hidden -fvisibility-inlines-hidden,这个我在简单的DEMO里面可以用,真正的工程里面死活不行,而且理论上来说对于依赖的其他静态库是没用的,这份方案后来放弃了。用–retain-symbols-file –version-script方案,这个很好用,只在exports.map里面输入要导出的符号就可以。

exports.map的例子:

{
global:func1;func2;
local: *;
};


动态库的使用

$(EXEC): $(OBJS) $(P_OUTLIB)/libBasicTool.a $(P_OUTLIB)/libFreeNet.so
$(CPP) $(CFLAGS) -o $@ $(OBJS) -L$(P_OUTLIB) -lBasicTool -lresolv -lrt -lFreeNet -lpthread


几点注意:

1. CFLAGS不能加-static

几个静态库合并成一个静态库

要先解压,然后一起合并。

LDLIBS = libBasicTool.a \
libNetwork.a \
libDynaStruct2.a \
libTinyXml.a

LIBSOBJS = ./build_tmp/libBasicTool.a/*.o \
./build_tmp/libNetwork.a/*.o \
./build_tmp/libDynaStruct2.a/*.o \
./build_tmp/libTinyXml.a/*.o

$(LIBTARGET): $(LIBOBJS)
rm -rf build_tmp
mkdir build_tmp
@for lib in $(LDLIBS); do \
mkdir build_tmp/$$lib;\
cd build_tmp/$$lib;\
$(AR) x $(P_OUTLIB)/$$lib;\
cd ../..;\
done
$(AR) rsuv $(LIBTARGET) $(LIBSOBJS) $(LIBOBJS)
ranlib $(LIBTARGET)
rm -rf build_tmp
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: