注意 此问题现已解决 - 请参阅下面的答案 - 除非有人删除此帖子,否则它只会记录我自己的愚蠢,我猜...仍然,使用C ++异常在Android JNI代码中工作的所有步骤和配置在下面都是正确的,所以它可能会偶尔帮助某人--Greg
我正在阅读有关此问题的所有可能材料,并且无法在静态构建的本机库中使我的C ++异常工作......任何想法我缺少什么?
Application.mk,如下所示,我尝试了gnustl_static和stlport_static,没有任何效果。我甚至强迫重建stlport_static ......
NDK_TOOLCHAIN_VERSION= 4.9
APP_PLATFORM := android-10
#APP_STL := gnustl_static
APP_STL := stlport_static
APP_CPPFLAGS += -fexceptions
APP_CPPFLAGS += -frtti
# STLPORT_FORCE_REBUILD := true
ifeq ($(NDK_DEBUG),1)
APP_OPTIM := debug
APP_ABI := x86
else
APP_OPTIM := release
APP_ABI := mips armeabi armeabi-v7a x86
endif
我正在尝试的代码:
//-----------------------------------------------------------------------
// Generic external error exception
struct ExternalException : public std::exception
{
public:
explicit ExternalException(const std::string &what)
: message(what) {}
virtual ~ExternalException() throw() {}
const char *what() const throw() { return message.c_str(); }
protected:
const std::string message;
};
然后在其他地方:
try
{
ret = SomeFunction();
}
catch (...)
{
ret = -1;
}
我也在catch (ExternalException& e) {...}
之上尝试过,也没有帮助。
SomeFunction()调用某个错误条件:
throw ExternalException(what);
然后应用程序崩溃了。当我分析堆栈跟踪时,我发现异常 Unwind ...()调用什么都不做,然后它会转到终止函数。
我觉得我的头撞在墙上......这里有什么问题???
仅供快速参考,以下是我的本地编译器选项:
LOCAL_CFLAGS += -Wno-write-strings -gdwarf-2
LOCAL_CFLAGS += -ffunction-sections -fdata-sections -fvisibility=hidden
LOCAL_CPPFLAGS += -ffunction-sections -fdata-sections -fvisibility=hidden
更新
以下是捕获的堆栈跟踪的一部分,这是在Nexus 6P设备上构建的armeabi-v7a。以前我在x86模拟器上测试了调试版本,完全相同的问题。接下来会尝试用不同的C / CPP标志进行测试,也许那里存在冲突?
********** Crash dump: **********
Build fingerprint: 'google/angler/angler:6.0.1/MMB29P/2473553:user/release-keys'
pid: 12307, tid: 12352, name: AsyncTask #4 >>> com.hyperionics.avar <<<
signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------
Stack frame #00 pc 00042374 /system/lib/libc.so (tgkill+12)
Stack frame #01 pc 0003ff81 /system/lib/libc.so (pthread_kill+32)
Stack frame #02 pc 0001c73f /system/lib/libc.so (raise+10)
Stack frame #03 pc 000198f1 /system/lib/libc.so (__libc_android_abort+34)
Stack frame #04 pc 000174b0 /system/lib/libc.so (abort+4)
Stack frame #05 pc 002ac143 /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine __gabixx::__default_terminate() at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/terminate.cc:75
Stack frame #06 pc 002ac14d /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine __gabixx::__terminate(void (*)()) at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/terminate.cc:84
Stack frame #07 pc 002ac1a5 /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine std::terminate() at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/terminate.cc:110
Stack frame #08 pc 002ab80f /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine __cxxabiv1::call_terminate(_Unwind_Control_Block*) at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/helper_func_internal.cc:54
Stack frame #09 pc 002ab21d /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine throwException at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/cxxabi.cc:271
Stack frame #10 pc 002ab2e1 /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine __cxa_throw at /tmp/ndk-user/tmp/build-stlport/ndk/sources/cxx-stl/gabi++/src/cxxabi.cc:335
Stack frame #11 pc 00045e58 /data/app/com.hyperionics.avar-1/lib/arm/libHyperionics_avar.so: Routine IOError(std::string const&, std::string const&) at C:\android\TtsNativeLib/jni/mylib/error.h:128 (discriminator 4)
格雷格
答案 0 :(得分:1)
简单地说,问题是什么:在我对SomeFunction()的调用中,我实际上有参数,而异常是在创建这些参数时,而不是在函数内部。只是我的尝试{&#39;指示必须向上移动......就像:
Ptr<OutPackedStream> pout = CreatePackedStream(fname.c_str());
try
{
ret = SomeFunction(pout);
}
catch (...)
{
ret = -1;
}
所以很明显我无法在CreatePackedStream()中捕获异常,因为它不在try {}内部......但令我困惑的是堆栈跟踪指向ret = SomeFunction(pout)
行,仅然后去了CreatePackedStream()
。现在查看代码,以及我的堆栈跟踪,这是非常明显的,再次抱歉我的笨拙!
格雷格