带有 DevIL 的 g++:无法链接
Posted
技术标签:
【中文标题】带有 DevIL 的 g++:无法链接【英文标题】:g++ with DevIL: unable to link 【发布时间】:2015-03-27 23:01:19 【问题描述】:首先,我正在使用 Fedora 并学习 OpenGL。我想稍微使用 DevIL,所以我从官方存储库安装了 DevIL 和 DevIL-ILUT 包。我有一个用于加载和渲染可用文件的测试代码,因此我决定对其进行测试(我将在我的课程中学习一些 DevIL 基础知识,我们获得了该文件以确保 DevIL 对我们正常工作)。
文件包含行:
#include "IL/devil_cpp_wrapper.hpp"
所以我把IL目录(我们也有)复制到有测试文件的目录下(IL目录包含很多头文件,例如il.h, ilut.h, ilu.h, ...) .但是,构建失败了
#include <IL/ilut.h>
来自 IL/devil_cpp_wrapper.hpp 文件。我不明白,因为我安装了软件包。我尝试将所有可能的参数都放入 g++(因为我没有找到任何有用的手册,也许我只是瞎了眼),-lIL、-lILU、-lILUT、-ldevil,因为每一种可能性都会给我同样的错误。我找不到任何合适的解决方案,所以我放弃并将 IL 目录也复制到 /usr/include。这次它给了我这个包含的每个库的错误:
/usr/bin/ld: cannot find <param>
所以我删除了该目录,并尝试用目录中的那些替换所有系统包含,如devil_cpp_wrapper.hpp 中的那个(因为文件被称为相同)。链接器也有同样的问题,所以我删除了所有库参数并尝试再次编译它,这次在 DevIL 特定函数的“未定义引用”上失败。
我们还提供了一些 dll 文件(DevIL.dll、ILU.dll、ILUT.dll)和 .lib 文件,我也尝试链接它们,但仍然得到相同的未定义引用错误。另外,这个课程主要是为 VS 用户制作的,所以我不确定我应该包含哪些文件。
我还尝试按照他们的 README.unix 文件中所写的方式从他们的 github 源代码构建 DevIL,但第一步失败(autoreconf -i 对某些 libILUT.la 失败;我也尝试了 autoconf -i,以防他们有写错了,未定义的win32宏失败)。
所以,我的问题是:我是一个无法链接 DevIL 的菜鸟。我尝试了我能想到的一切,但找不到任何解决方案。谁能帮帮我?
编辑:由于从 github 构建失败,我决定给它一个机会并下载他们的 .tar 并尝试从中编译。一开始它似乎在工作,但随后 make 返回“对 `png_set_gray_1_2_4_to_8' 的未定义引用”和“collect2:错误:ld 返回 1 个退出状态”。即使在此之后,我也尝试使用 make install 完成构建,当然这也失败了,但在这次尝试中,我将一些库放入 /usr/local/lib。但是,我仍然无法编译我的测试程序,因为提到的对 png_set_gray_1_2_4_to_8 的未定义引用,链接器现在抱怨。
【问题讨论】:
你不要在 Linux 上使用 DLL,它们是 Windows 的东西。 【参考方案1】:在 Linux 上使用库有很多选择。这通常相当容易,但您似乎偶然发现了一些常见的问题。
规则 #1:不要自己触摸 /usr
或 /usr/local
。
/usr
目录用于存放系统安装的软件包(例如 Debian、Ubuntu 或 Mint 上的 apt-get
),因此您几乎永远不要触摸它。
/usr/local
目录用于您 安装的软件包(假设您是机器的管理员),但您不手动将文件复制到那里。相反,您运行的安装脚本会自动将文件放在那里。
通常,您会这样安装:
./configure
make
sudo make install
规则 #2:首先使用包管理器。
包管理器取决于您使用的 Linux 发行版。例如,在基于 Debian 的系统上,软件包系统为“apt”,您可以使用 synaptic、aptitude 或 apt-get 来安装软件包。
在我的系统上,我会运行以下命令:
sudo apt-get install libdevil-dev
-dev
表示“开发”,因此它包含编译使用 DevIL 的程序所需的头文件。
规则 #3:如果您从源代码编译,请在查看 GitHub 之前获得适当的版本。
正确的版本会有configure
脚本。因为你是从 GitHub 下载的,所以你必须调用 autoconf
,这意味着在你的系统上安装更多的包。不要打扰,只需获取适当的源代码版本即可。
规则 #4:始终使用构建系统。
你没有提到你是如何编译的,所以我担心你可能只是在命令行上输入gcc
。这是令人沮丧的秘诀。
这是一个makefile,你可以用它来编译一个使用DevIL的简单C++程序,假设你的程序都在main.cpp
中:
all: myprog
clean:
rm -f myprog *.o
devil_cflags := $(shell pkg-config --cflags IL)
devil_libs := $(shell pkg-config --libs IL)
CXXFLAGS := -O0 -g -Wall -Wextra $(devil_cflags)
LIBS := $(devil_libs)
myprog: main.o
c++ $(LDFLAGS) -o $@ $^ $(LIBS)
这使用pkg-config
来确定如何与 DevIL 链接。这比自己编写链接器标志要好得多。
请注意,Makefile 中的缩进必须使用制表符完成,不能使用空格。
【讨论】:
感谢您提供大量信息(我不知道#1,也许修补我唯一可用的系统不是一个好主意)。我确实使用了包管理器并下载了正确的和 github 源代码,但它也没有构建。感谢您的回答,我发现了问题 - 我没有下载 DevIL-devel 包(只有我在帖子中提到的两个)。之后,编译和运行测试程序就可以工作了。【参考方案2】:为了添加新库,您应该将 lib 和包含目录中的文件复制到 usr 文件夹中的适当位置。否则编译器找不到你的库在哪里。
我不确定目录名称,但它应该放在这些文件夹中:
对于标题: usr/local/include
对于库: usr/local/lib
【讨论】:
感谢您的尝试,但我似乎没有可用的 Linux 库。我得到的 .lib 文件是用于 Windows 的(至少我认为它们不会工作),并且 DevIL 源中的 lib 目录是空的。但是,我尝试从另一个来源构建它(参见编辑),效果更好,但仍然没有解决所有问题。丢失的库似乎是问题所在(感谢您澄清这一点),但我无法获取它们并且无法从源代码构建 DevIL(而且我不知道,为什么安装包不起作用?)。 @Adalee 您是否像在这个问题中那样安装了它?如果是,您不需要手动复制文件。它应该是自动放置的。***.com/questions/8334842/… 是的,我使用了来自同一个站点的同一个 .tar 源。我的构建在第二点使用 make 失败。我检查了他们提到的成功构建它所需的库,似乎我拥有它们。以上是关于带有 DevIL 的 g++:无法链接的主要内容,如果未能解决你的问题,请参考以下文章
使用带有 nvcc 的 -G 标志编译为 cubin 后,Cublas 无法在内核中工作
g ++链接器:/usr/lib/libGL.so.1:无法读取符号:无效操作