NativeActivity:找不到符号“_ZSt11_Hash_bytesPKvjj”

时间:2013-11-11 22:16:38

标签: android c++ c++11 native-activity

我正在尝试使用NativeActivity使用C ++ 11和OpenGL ES for Android编译应用程序。我正在使用

APP_STL := gnustl_shared

一切都很好。但是当我运行我的应用程序时,我得到了:

dlopen(libjngl-test.so): Cannot load library: soinfo_relocate(linker.cpp:976): cannot locate symbol "_ZSt11_Hash_bytesPKvjj" referenced by "libjngl-test.so"...

jngl-test是我的活动。这就是我的加载代码的样子:

#include <android/native_activity.h>
#include <android/log.h>
#include <dlfcn.h>
#include <errno.h>
#include <stdexcept>

void* load_lib(const std::string& l) {
    auto handle = dlopen(std::string("/data/data/com.bixense.jngl_test/lib/" + l).c_str(),
                         RTLD_NOW | RTLD_GLOBAL);
    if (!handle) {
        throw std::runtime_error(std::string("dlopen(") + l + "): " + dlerror());
    }
    __android_log_print(ANDROID_LOG_INFO, "bootstrap", "Loaded %s", l.c_str());
    return handle;
}

void ANativeActivity_onCreate(ANativeActivity* app, void* ud, size_t udsize) {
    try {
        load_lib("libogg.so");
        load_lib("libvorbis.so");
        auto main = reinterpret_cast<void (*)(ANativeActivity*, void*, size_t)>(
            dlsym(load_lib("libjngl-test.so"), "ANativeActivity_onCreate")
        );
        if (!main) {
            throw std::runtime_error("undefined symbol ANativeActivity_onCreate");
        }
        main(app, ud, udsize);
    } catch(std::exception& e) {
        __android_log_print(ANDROID_LOG_ERROR, "bootstrap", "%s", e.what());
        ANativeActivity_finish(app);
    }
}

有人知道我做错了什么吗? _ZSt11_Hash_bytesPKvjj来自哪里?

0 个答案:

没有答案