shm_open : DSO Missing From Command Line 上的 C++ Boost 库 undefined reference

标签 c++ linux ubuntu gcc boost

我正在编写一个应用程序,它将在 DDS 系统中扮演订户的角色。此订阅者将在收到数据后将值写入共享内存位置,以便其他 GUI 应用程序可以读取它们。

我已经编写了一个在 Windows 上编译和运行 A-OK 的应用程序版本,但我现在面临创建一个在 Ubuntu 上运行的版本。作为 Windows 原生,这对我来说很麻烦。

为了创建 Ubuntu 版本,我已将我的代码库移植到 Ubuntu VM,现在正尝试在那里编译它,这正是我遇到问题的地方。

在大多数情况下,一切都可以正常编译,并且过程与 Windows 上的过程非常相似。不幸的是,链接我生成的所有 .o 文件的最后一条语句失败了。下面是一些描述:

我正在使用 boost 进程间库编写将提供共享内存读/写操作的头文件。实现这一点的 .cpp 如下: MemWriterH.cpp

#define BOOST_DATE_TIME_NO_LIB
#define CPP

#include <boost/interprocess/shared_memory_object.hpp>
#include <boost/interprocess/mapped_region.hpp>
#include <stdio.h>
#include <MemWriterH.h>

using namespace boost::interprocess;

extern "C" int writeToSharedMemory(char *data)
{
    //Remove shared memory on construction and destruction
    struct shm_remove
    {
        shm_remove()
        {
            //shared_memory_object::remove("MySharedMemory");
        }
        ~shm_remove()
        {
            //shared_memory_object::remove("MySharedMemory");
        }
    }remover;

    //Create a shared memory object.
    shared_memory_object shm(open_or_create, "MySharedMemory", read_write);
    //Set size
    shm.truncate(1000);

    //Map the whole shared memory in this process
    mapped_region region(shm, read_write);

    //Write given data to the mapped region
    //std::memset(region.get_address(), 'h', region.get_size());
    std::memcpy(region.get_address(), data, region.get_size());

    return 0;
}

extern "C" void readFromSharedMemeory(char toWriteIn[])
{
    //Open already created shared memory object.
    shared_memory_object shm(open_only, "MySharedMemory", read_only);

    //Map the whole shared memory in this process
    mapped_region region(shm, read_only);

    //Read data from shared memory into parameter
    //char *mem = static_cast<char*>(region.get_address());

    std::memcpy(toWriteIn, region.get_address(), region.get_size());
    printf("Read data OK");
    printf("\n%s", toWriteIn);
}

及其附带的 header :MemWriterH.h

#ifdef CPP
    extern "C" int writeToSharedMemory(char *);
    extern "C" void readFromSharedMemeory(char *);
#else
    int writeToSharedMemory( char *);
    void readFromSharedMemeory(char* toWriteIn);
#endif

然后使用以下方法将它们编译为 .o 文件:

g++ -c -I/$HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_INCLUDES/MEM_MAPPING/ *.cpp

在应用程序的主文件中,我有一个#include 允许使用上述功能。

虽然此应用程序还有各种其他元素(如下所示),但这些元素似乎都可以正常编译、构建和链接。

此生成的 MemWriterH.o 文件然后用于最终的 GCC 语句——我相信——将所有 .o 文件链接在一起以生成应用程序的可执行文件。最后的声明是:

gcc HID_LDM_DDS_SUB.o $HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_HELPER/HID_LDM_DDS_HELPER.o $HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_INCLUDES/CheckStatus.o $HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_INCLUDES/MEM_MAPPING/MemWriterH.o $HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_IDL/LDMSacDcps.o $HOME/workspace_c/HID_LDM_DDS/HID_LDM_DDS_IDL/LDMSplDcps.o $OSPL_HOME/lib/libddskernel.so $OSPL_HOME/lib/libdcpssac.so

不幸的是,这给了我错误:

/usr/bin/ld: /home/bob/workspace_c/HID_LDM_DDS/HID_LDM_DDS_INCLUDES/MEM_MAPPING/MemWriterH.o: undefined reference to symbol 'shm_open@@GLIBC_2.2'

/lib/i386-linux-gnu/librt.so.1: error adding symbols: DSO missing from command line collect2: error: ld returned 1 exit status

在这一点上,我感到完全迷失了。 .cpp 毫无怨言地编译成 .o,所以我不太确定从这里还能去哪里。什么是 DSO,如何将它添加到命令行?

编辑:

现在问题已经解决了更新。作为Sehe下面指出,缺少定义 shm_open 的库。这包含在 -lrt 标志中,它应该包含在被链接的 .o 文件之后 ( see here for more explanation on that )。

然而,解决这个问题确实会导致另一个问题,即编译器会提示多次出现类似以下行的错误:“对 std::some_function 的 undefined reference ”。事实证明,这是由于使用 gcc 命令链接 C 和 C++ 代码( header )时出现的问题。添加 -lstdc++ 标志或使用 g++ 编译命令 ( see the answer here for a description of what's going on ) 也可以解决此问题,并且所有编译均成功。

最佳答案

您应该完全按照消息的建议简单地添加缺少的库:链接器选项末尾的 -lrt 就足够了

关于shm_open : DSO Missing From Command Line 上的 C++ Boost 库 undefined reference ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31969232/

相关文章:

c++ - 是否可以从输入流中读取 'throw away' 值?

linux - 如何创建包含内容(文件/目录)的 ext3 文件系统并将它们打包到二进制文件中?

php - 努力在 Centos 上安装 PHP pecl

ubuntu - 单击按钮从另一个事件中的事件返回 React-native

ubuntu - 无法在 AWS ec2 实例中将我的网站作为 https 启动

java - EDITLogBack Syslog 不工作 java

c++ - 如何在 C++ 中将无符号长整数 (DWORD) 重新解释为有符号长整数?

c++ - "make"使用模式匹配时失败

c++ - 错误的输出 - Ramanujan 对阶乘和 C++ 的近似

c++ - 使用 C++ 在 Linux 中计算磁盘读写