c++ - ldd 输出静态链接到共享库

标签 c++ java-native-interface shared-libraries ldd

我正在尝试创建一个共享库 libddv3djava.so

我像这样编译 libddv3djava.so 的源代码:

~/Programming/intellijprojects/ddv3dbindingstest/src $ g++ -c -Wall -Werror -I. -I /usr/lib/jvm/java-8-oracle/include/ -I /usr/lib/jvm/java-8-oracle/include/linux/ -fpic com_ddv3d_Ddv3dBinding.cpp

创建 libddv3djava.so:

~/Programming/intellijprojects/ddv3dbindingstest/src $ g++ -shared -o libddv3djava.so com_ddv3d_Ddv3dBinding.o

当我在 libddv3djava.so 上执行 ldd 时:

~/Programming/intellijprojects/ddv3dbindingstest/src $ ldd libddv3djava.so         statically linked

问题:

它说 libddv3djava.so 是静态链接。我用 -shared 创建了 libddv3djava.so,所以这让我很困惑。

问题:

当 libddv3djava.so 不是静态链接时,为什么 ldd 输出静态链接?

附加信息:

我不确定以下内容是否相关,但可能相关; libddv3djava.so 依赖于我创建的另一个名为 libddv3d.so 的共享库。基本上 libddv3djava.so 是一个围绕 libddv3d.so 的 JNI 包装器。发帖来源:

com_ddv3d_Ddv3dBinding.h:

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class com_ddv3d_Ddv3dBinding */

#ifndef _Included_com_ddv3d_Ddv3dBinding
#define _Included_com_ddv3d_Ddv3dBinding
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     com_ddv3d_Ddv3dBinding
 * Method:    initialize
 * Signature: ()V
 */
JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_initialize
  (JNIEnv *, jobject);

/*
 * Class:     com_ddv3d_Ddv3dBinding
 * Method:    sendDrawableData
 * Signature: (FFFFFFFI)V
 */
JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_sendDrawableData
  (JNIEnv *, jobject, jfloat, jfloat, jfloat, jfloat, jfloat, jfloat, jfloat, jint);

/*
 * Class:     com_ddv3d_Ddv3dBinding
 * Method:    finished
 * Signature: ()Z
 */
JNIEXPORT jboolean JNICALL Java_com_ddv3d_Ddv3dBinding_finished
  (JNIEnv *, jobject);

/*
 * Class:     com_ddv3d_Ddv3dBinding
 * Method:    cleanup
 * Signature: ()V
 */
JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_cleanup
  (JNIEnv *, jobject);

#ifdef __cplusplus
}
#endif
#endif

com_ddv3d_Ddv3dBinding.cpp:

#include <jni.h>
#include <ddv3d.h>
#include "com_ddv3d_Ddv3dBinding.h"

JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_initialize(JNIEnv *env, jobject thisObj)
{
    ddv3d::initialize();
    return;
}
JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_sendDrawableData(JNIEnv *env, jobject thisObj,
                jfloat positionX, jfloat positionY, jfloat positionZ,
                jfloat angle,
                jfloat rotationAxisX, jfloat rotationAxisY, jfloat rotationAxisZ,
                jint type)
{
    ddv3d::sendDrawableData(positionX, positionY, positionZ,
                angle,
                rotationAxisX, rotationAxisY, rotationAxisZ,
                type);
    return;
}
JNIEXPORT jboolean JNICALL Java_com_ddv3d_Ddv3dBinding_finished(JNIEnv *env, jobject thisObj)
{
    return ddv3d::finished();
}
JNIEXPORT void JNICALL Java_com_ddv3d_Ddv3dBinding_cleanup(JNIEnv *env, jobject thisObj)
{
    ddv3d::cleanup();
    return;
}

最佳答案

ldd 显示库或可执行文件需要哪些共享库。 在这种情况下没有,因为 libddv3djava.so 是静态链接的。

编译器标志 -fpic 和链接器标志 -shared 使 libddv3djava.so 可以用作共享对象,这是其他东西。

要使 libddv3djava.so 依赖于共享库文件 libddv3d.so,必须将其添加到链接器命令中。

g++ -shared -o libddv3djava.so -lddvd3d com_ddv3d_Ddv3dBinding.o

如果找不到 libddv3d.so,您可以使用 -L 标志添加额外的路径进行搜索。

关于c++ - ldd 输出静态链接到共享库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24491381/

相关文章:

java - 在 JNI 中,如何从 native 代码访问静态 Java 变量

linux - 如何避免在物理内存中共享库文本节的多个副本?

C++强制覆盖

java - 只需要帮助启动一个从 c++/c 转移到 mips 的程序

c++ - 函数模板重载解决方案和编译器优化

c++ - cv::namedWindow() 在调用时挂起

java - JNI 回调线程

android - 无法将 minizip 代码加载到 Android JNI 中。链接 libminizip.so 失败

c++ - 在 C++ 共享库中添加通用日志记录支持

c++ - 我应该如何在 Win32 C++ 应用程序中集成和打包此第三方库?