5

我有一个用于 c++ Linux 项目的 Makefile:

MODE ?= dbg
DIR = ../../../../../somdir/$(MODE)

SRC_FILES = a.cpp b.cpp
H_FILES = a.h

LDFLAGS += -L$(DIR)/lib/linux '-Wl,-R$$ORIGIN'
CPPFLAGS = -I$(DIR)/include
LIBRARIES = -lsomeso

ifeq (rel, $(MODE))
  CFLAGS = -Wall -g -DNDEBUG
else
  CFLAGS = -Wall -ansi -pedantic -Wconversion -g -DDEBUG -D_DEBUG
endif

sample: $(SRC_FILES) $(H_FILES) Makefile
    g++ $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) $(LIBRARIES) $(SRC_FILES) -o sample

当我运行“make”时,它会构建项目,没有错误。但是当我运行该项目时,它抱怨说:

error while loading shared libraries: libsomeso.so: cannot open shared object file: No such file or directory

我在 DIR 中给出的路径转到保存共享对象的文件夹(相对于放置 makefile 的位置),如果它是错误的路径,为什么它在 make 过程中不抱怨。

有人知道我错过了什么吗?

谢谢马特

4

5 回答 5

5
LDFLAGS += -L$(DIR)/lib/linux '-Wl,-R$$ORIGIN'

以上应该是:

LDFLAGS += -L$(DIR)/lib/linux -Wl,-R$(DIR)/lib/linux '-Wl,-R$$ORIGIN'

也就是说,对于每个非标准动态库位置,都应该指定-L一个对应的位置。需要定位相对于可执行文件的动态库,不确定您是否需要它。-Wl,-R$ORIGIN

人们经常建议使用LD_LIBRARY_PATH. 在我看来,这是一个糟糕的建议,因为它使部署更加复杂。

于 2013-02-25T10:56:45.233 回答
2

当你运行你的应用程序时,位置libsomeso.so应该在LD_LIBRARY_PATH环境变量中。尝试运行这样的程序:

LD_LIBRARY_PATH="path_to_libsomeso_so:$LD_LIBRARY_PATH" myprogram

这是所在目录path_to_libsomeso_so的完整路径,并且是您的程序可执行文件。请注意,您应该指定包含 的目录的路径,而不是文件本身。libsomeso.somyprogramlibsomeso.solibsomeso.so

于 2013-02-25T10:29:44.167 回答
1

问题不在编译期间。一切顺利。运行时出现问题。

实际上,您的程序已与共享对象库链接。因此,在运行时,它需要加载这个共享对象文件。-L在编译期间,您可以使用标志指示编译器此文件所在的位置。

对于运行时,您必须将LD_LIBRARY_PATH环境变量设置为指向libsomeso.so文件所在的目录。

或者,您可以将此文件放在搜索这些共享对象文件的标准目录之一中:/usr/local/lib, /usr/lib, /lib,但这应该是您为库的最终分发版本所做的。

于 2013-02-25T10:32:00.850 回答
1

正如 Maxim Egorushkin 所说,LD_LIBRARY_PATH这是一个糟糕的选择。同时,使用-L$(your lib path) -l$(your lib name)gcc/g++ 参数链接共享库也不是一个好的选择。因为,在构建 exe 之后,您应该告诉 exe 共享库目录在哪里。默认情况下,可执行文件仅在/usr/lib或处搜索共享库/usr/local/lib。虽然,您在构建可执行文件时已经告诉 makefile 共享库在哪里。但是当你执行这个exe文件时,它们是不同的。但是,链接静态库没有这样的问题。

因此,解决问题的最佳方法是更改​​链接自定义共享文件的方式。像这样:

DYNAMIC_LIB_DIR = ../lib (your lib path ,this is a example)

OBJLIBS = xxx.so (your lib name)

gcc/g++ -o exe_name sourcefile/object_file $(DYNAMIC_LIB_DIR)/$(OBJLIBS)
于 2016-07-26T12:36:04.457 回答
0

刷新动态库缓存!

在向 中添加自定义的非标准库后/usr/local/lib,首先检查./usr/local/lib/etc/ld.so.conf.d/libc.conf

然后,以动态链接库缓存刷新结束:

$ sudo ldconfig
于 2017-11-18T09:49:39.693 回答