【问题标题】:"UnsatisfiedLinkError" appears when "dynamic_cast" is used in Android NDKAndroid NDK 中使用“dynamic_cast”时出现“UnsatisfiedLinkError”
【发布时间】:2012-04-10 11:35:58
【问题描述】:

我是 Android 开发的新手,我面临下一个问题: 当我使用使用 "dynamic_cast" 表达式的 C++ 代码时 - 当我在模拟器上启动我的应用程序时会出现 "UnsatisfiedLinkError"。但是当我在没有它的情况下运行应用程序时 - 一切正常(我的意思是 LogCat 没有任何错误)

我尝试在 Android 2.3.3 上运行它。我用的是 android-ndk-r7b。

我的应用程序.mk:

APP_OPTIM := debug
APP_ABI := armeabi
APP_STL := gnustl_static
APP_MODULES := native_lab

我的 Android.mk:

LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE    := native_lab
LOCAL_SRC_FILES := native.cpp enum_if.cpp torrent.cpp
LOCAL_CPP_FEATURES := rtti exceptions
LOCAL_LDLIBS := -llog -lz \
    /home/l/android9_toolchain/arm-linux-androideabi/lib/libstdc++.a
LOCAL_C_INCLUDES := $(LOCAL_PATH)/include
include $(BUILD_SHARED_LIBRARY)

使用动态转换的代码片段:

namespace libtorrent 
{
    template <class T>
    T* alert_cast(alert* a)
    {
        return dynamic_cast<T*>(a);
    }
}
.....

using namespace libtorrent;
if (torrent_finished_alert* p = alert_cast<torrent_finished_alert>(a)){}

原木猫说:

03-27 07:28:26.465: D/dalvikvm(404): Trying to load lib /data/data/com.example/lib/libnative_lab.so 0x405149b8
03-27 07:28:26.496: W/dalvikvm(404): Exception Ljava/lang/UnsatisfiedLinkError; thrown while initializing Lcom/example/Bt2Activity;
03-27 07:28:26.555: W/dalvikvm(404): Class init failed in newInstance call (Lcom/example/Bt2Activity;)
03-27 07:28:26.555: D/AndroidRuntime(404): Shutting down VM
03-27 07:28:26.575: W/dalvikvm(404): threadid=1: thread exiting with uncaught exception (group=0x40015560)
03-27 07:28:26.615: E/AndroidRuntime(404): FATAL EXCEPTION: main
03-27 07:28:26.615: E/AndroidRuntime(404): java.lang.ExceptionInInitializerError
03-27 07:28:26.615: E/AndroidRuntime(404):  at java.lang.Class.newInstanceImpl(Native Method)

有人知道如何解决这个问题吗?

【问题讨论】:

  • "UnsatisfiedLinkError" - 错误的文本是否不止这些?如果是这样,请将其包含在问题中。
  • 我添加了来自 LogCat 的错误跟踪

标签: android c++ dynamic android-ndk dynamic-cast


【解决方案1】:

很可能模拟器中可能存在错误。如果您可以在没有模拟器的情况下测试您的应用程序,那么一切都会正常工作。我认为模拟器中有一些逻辑错误会产生这个问题。类似当你调用 alert_cast(a)){} 时,你传递的引用 torrent_finished_alert 在模拟器上是不可测试的,这段代码必须在模拟器中编码,即动态转换运算符。

【讨论】:

    【解决方案2】:

    尝试将这些行包含到您的 Applications.mk 中:

    APP_CPPFLAGS += -frtti 
    APP_CPPFLAGS += -fexceptions
    

    您在 Java 中是否有任何标记为“本机”的方法?

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-05-17
      • 2011-07-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-06-09
      相关资源
      最近更新 更多