如何使错误日志更详细地了解未定义的引用

时间:2012-10-09 06:48:58

标签: android c++ c android-ndk cygwin

我需要编译一些c / c ++代码。使用NDK和Cygwin的工具,不止一次我提出错误“未定义引用”。大多数人都说它是由调用一个函数引起的,该函数的源文件中没有包含lib文件。但是,我对c / c ++知之甚少,而且错误日志也提供了模糊信息,因此我无法知道哪个行导致问题,甚至不知道哪个lib文件是我真正需要的。

我希望我找到一些工具或一些方法来处理这样的问题,这样我就可以找到错误行或者获得有关错误的更多细节。

非常感谢。

Android.mk

LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
include ../includeOpenCV.mk
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include $(TOOLCHAIN_PREBUILT_ROOT)/user/share/OpenCV/OpenCV.mk
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE:=AvatarSpeak
LOCAL_SRC_FILES:=AvatarSpeak.cpp
LOCAL_LDLIBS    := -llog
include $(BUILD_SHARED_LIBRARY)

$ NDK / ndk-build V = 1

$ $NDK/ndk-build V=1
rm -f ./libs/armeabi/lib*.so ./libs/armeabi-v7a/lib*.so ./libs/mips/lib*.so        ./libs/x86/lib*.so
rm -f ./libs/armeabi/gdbserver ./libs/armeabi-v7a/gdbserver ./libs/mips/gdbserver     ./libs/x86/gdbserver
rm -f ./libs/armeabi/gdb.setup ./libs/armeabi-v7a/gdb.setup ./libs/mips/gdb.setup      ./libs/x86/gdb.setup
Gdbserver      : [arm-linux-androideabi-4.6] libs/armeabi/gdbserver
mkdir -p ./libs/armeabi
install -p /cygdrive/d/android-ndk-r8b/prebuilt/android-arm/gdbserver/gdbserver   ./libs/armeabi/gdbserver
Gdbsetup       : libs/armeabi/gdb.setup
mkdir -p ./libs/armeabi
echo "set solib-search-path ./obj/local/armeabi" > ./libs/armeabi/gdb.setup
echo "directory D:/android-ndk-r8b/platforms/android-14/arch-arm/usr/include   "../../OpenCV-2.3.1/share/OpenCV/../../include/opencv" "../../OpenCV-    2.3.1/share/OpenCV/../../include" D:/android-ndk-r8b/sources/cxx-stl/gnu-     libstdc++/4.6/include D:/android-ndk-r8b/sources/cxx-stl/gnu-    libstdc++/4.6/libs/armeabi/include jni" >> ./libs/armeabi/gdb.setup
SharedLibrary  : libAvatarSpeak.so
/cygdrive/d/android-ndk-r8b/toolchains/arm-linux-androideabi-     4.6/prebuilt/windows/bin/arm-linux-androideabi-g++  -Wl,-soname,libAvatarSpeak.so  -shared       --sysroot=D:/android-ndk-r8b/platforms/android-14/arch-arm  ./obj/local/armeabi/objs-      debug/AvatarSpeak/com_huawei_avatar_AvatarSpeak.o ./obj/local/armeabi/libopencv_contrib.a       ./obj/local/armeabi/libopencv_calib3d.a ./obj/local/armeabi/libopencv_objdetect.a       ./obj/local/armeabi/libopencv_features2d.a ./obj/local/armeabi/libopencv_video.a      ./obj/local/armeabi/libopencv_imgproc.a ./obj/local/armeabi/libopencv_highgui.a          ./obj/local/armeabi/libopencv_ml.a ./obj/local/armeabi/libopencv_legacy.a     ./obj/local/armeabi/libopencv_flann.a ./obj/local/armeabi/libopencv_core.a        ./obj/local/armeabi/libopencv_androidcamera.a ./obj/local/armeabi/liblibjpeg.a       ./obj/local/armeabi/liblibpng.a ./obj/local/armeabi/liblibtiff.a      ./obj/local/armeabi/liblibjasper.a ./obj/local/armeabi/libzlib.a       ./obj/local/armeabi/libgnustl_static.a    -Wl,--no-undefined -Wl,-z,noexecstack -Wl,-      z,relro -Wl,-z,now  -LD:/android-ndk-r8b/platforms/android-14/arch-arm/usr/lib -llog -lc -           lm  -o obj/local/armeabi/libAvatarSpeak.so
./obj/local/armeabi/objs-debug/AvatarSpeak/AvatarSpeak.o: In function      `Java_com_hachi_avatar_AvatarSpeak_speak':
D:\eclipse_workspace\TestSo/jni/com_hachi_avatar_AvatarSpeak.cpp:52: undefined     reference to `Fap2Avi2D(char const*, char const*, char const*, char const*, char const*,    int)'
collect2: ld returned 1 exit status
/cygdrive/d/android-ndk-r8b/build/core/build-binary.mk:378: recipe for target     `obj/local/armeabi/libAvatarSpeak.so' failed
make: *** [obj/local/armeabi/libAvatarSpeak.so] Error 1

AvatarSpeak.cpp

if (fImage != NULL && fPot != NULL) {

    bool sucavi = Fap2Avi2D(str3, str5, str4, str1, str2, -1);
    LOGI("sucess and exit!");
} else {
    LOGI("unsucess and exit!");
}

Animation2D_new.h (定义方法的头文件 Fap2Avi2D

#ifndef ANIMATION_2D_NEW_H_
#define ANIMATION_2D_NEW_H_

#include <vector>
#include <string>
#include "public.h"
#include "FaceExpressionEditor.h"
//#define  __declspec(dllexport)

bool Fap2Avi2D(const char *fap_file,const char *avi_file,const char *wav_file, const   char* image_file,const char *pot_file=NULL,int codec_type=-1);
...

2 个答案:

答案 0 :(得分:1)

“未定义的引用”通常意味着您的构建配置错误。例如,Android.mk文件中的意外换行符可能会导致 make 工具为您的项目选择错误的链接命令。

通常,错误消息包括缺少的函数或全局变量的名称,以及正在查找此引用的模块(文件)。如果名称不是不言自明的,您通常可以在源代码中找到此名称,然后将其追溯到您使用的外部库之一,因为它可能是声明您的来源中包含一些标题( .h .hpp )文件。

你不可能无意中使用一些你必须下载的外部库,因为当编译器找不到必要的include(头文件)文件时,通常会出现这种错误。

Android本机项目显示“未定义引用”错误的一个特例是当项目使用非官方Android API时,例如OpenMax的/ stagefreight。在这种情况下,头文件可以在Android源代码树中找到,但链接阶段所需的编译库不存在。通常的解决方法是从开发设备中提取二进制文件,例如

adb pull /system/lib/libstagefreight.so .

无论如何,使用 V = 1 运行ndk-build通常有助于确切了解执行的构建命令。

答案 1 :(得分:0)

找不到“丢失的库”没有通用的方法。这是您必须激活您作为程序员(和Google用户)的技能的地方。

第一步始终是确定该功能属于哪个库。使用Google总是一个不错的选择。

当您知道这一点时,您需要确定您的系统上是否安装了该库。如果没有,那就这样做。

然后,您需要将此依赖项添加到构建系统。如何完成取决于所使用的环境和工具。谷歌再次是你最好的选择。