在Android NDK库.a文件中,gnustl_shared和gnustl_static有什么区别

What is the difference between gnustl_shared and gnustl_static in Android NDK library .a file?

本文关键字:gnustl shared 区别 什么 static NDK Android 文件      更新时间:2023-10-16

我想使用c++stl创建android库。

我的构建工具是visualstudio2015,visualgdb。

源代码是

.cpp

#include <jni.h>
#include "AndroidProject2.h"
#include <vector>
void foo() { std::vector<int> aaa; aaa.push_back(1); }

Android.mk

# Generated by VisualGDB
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE    := AndroidProject2-shared
LOCAL_SRC_FILES := AndroidProject2.cpp
COMMON_SRC_FILES := $(LOCAL_SRC_FILES)
include $(BUILD_SHARED_LIBRARY)
include $(CLEAR_VARS)
LOCAL_MODULE    := AndroidProject2-static
LOCAL_SRC_FILES :=  $(COMMON_SRC_FILES)
include $(BUILD_STATIC_LIBRARY)

应用程序.mk

APP_MODULES := AndroidProject2-static AndroidProject2-shared
APP_ABI := all
APP_STL := gnustl_static
NDK_TOOLCHAIN_VERSION :=4.9

我成功构建了,所以创建了lib文件libAndroidProject2-static.a,libAndroidProject2-static.so

比,我尝试更改Application.mk 中的APP_STL选项

APP_MODULES := AndroidProject2-static AndroidProject2-shared
APP_ABI := all
APP_STL := gnustl_shared
NDK_TOOLCHAIN_VERSION :=4.9

当然,成功构建。因此,创建了lib文件libAndroidProject2-shared.a,libAndroidProject2-shared.so

相比之下,我将其与以前的构建输出进行比较。

我发现.so文件的不同之处。gnustl_static选项的.so文件比gnustl_shared选项的it文件大。但是.a是一样的。

为什么?我用了nm,但找不到区别。什么是diff???

这里有两个问题:

为什么使用gnustl_static会生成比gnustl_shared更大的共享库

当您使用静态库时,您会将该库中的代码直接包含到共享库中,这样您的库就会增长。当你使用共享库时,你会加载其他共享库中包含的代码,而不是包含它。你需要比较的大小是libAndroidProject2-static.so+libgnustl_shared.so,因为两者都必须在运行时存在。

为什么不使用gnustl_static创建一个更大的静态库

静态库(在本例中为libAndroidProject2-Static.a)没有链接;它们只是汇编资料的档案。直到您真正将libAndroidProject-static.a链接到某个东西中,libgnustl_static.a才会包含在内,此时您还需要链接libgnustl_static.a

当您将libAndroidProject2-static.a(和libgnustl_static.a)链接到共享库或可执行库时,您会看到大小差异。

不同之处在于,当您使用static时,std的代码会编译到生成的.so文件中,而使用shared时,生成的so文件需要在单独的so文件中有std