【问题记录】c++编译报错~/bin/ld.exe: cannot find 0

2024-05-01 07:04

本文主要是介绍【问题记录】c++编译报错~/bin/ld.exe: cannot find 0,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

构建环境

windows 11
cmake 3.29.0-rc2
MinGW 8.1.0

先说结论

推测这应该是MinGW和cmake版本的部分不兼容导致的,尝试使用旧一点的cmake或新一些的MinGW或许会解决这个问题。

诡异的 0 是怎么来的

首先这个程序没有链接任何外部库,也没导出任何库;
我通过添加cmake -- VERBOSE=1参数查看详细信息后发现问题出在build.make文件中的这一句命令

F:/MinGW/bin/c++.exe -g \
-Wl,--whole-archive CMakeFiles/print_hello_world.dir/objects.a \
-Wl,--no-whole-archive -o print_hello_world.exe \
-Wl,--out-implib,"" \
-Wl,--major-image-version,0,--minor-image-version,0 @CMakeFiles/print_hello_world.dir/linkLibs.rsp

经过分析问题是在--out-implib,""这个参数,不明白cmake为什么会生成这一句,似乎这个版本的c++.exe没有将""识别为空 ,并且又把--major-image-version后面的主版本号0识别为了一个库,所以才出现了这个链接错误,删除-Wl,--out-implib,""或主版本号0后恢复正常,这里肯定是选择删除-Wl,--out-implib,""才符合语义。
另外如果链接了第三方库,反而不会出问题。

修正前报错~/bin/ld.exe: cannot find 0

F:/MinGW/bin/c++.exe -g \
-Wl,--whole-archive CMakeFiles/print_hello_world.dir/objects.a \
-Wl,--no-whole-archive -o print_hello_world.exe \
-Wl,--out-implib,"" \
-Wl,--major-image-version,0,--minor-image-version,0 @CMakeFiles/print_hello_world.dir/linkLibs.rsp

修正后正常

F:/MinGW/bin/c++.exe -g \
-Wl,--whole-archive CMakeFiles/print_hello_world.dir/objects.a \
-Wl,--no-whole-archive -o print_hello_world.exe \
-Wl,--major-image-version,0,--minor-image-version,0 @CMakeFiles/print_hello_world.dir/linkLibs.rsp

链接gtest静态库后

源码结构没有变化,但该行参数变成了-Wl,--out-implib,libtest_print_hello_world.dll.a

F:/MinGW/bin/c++.exe -g \
-Wl,--whole-archive CMakeFiles/test_print_hello_world.dir/objects.a \
-Wl,--no-whole-archive -o test_print_hello_world.exe \
-Wl,--out-implib,libtest_print_hello_world.dll.a \
-Wl,--major-image-version,0,--minor-image-version,0 @CMakeFiles/test_print_hello_world.dir/linkLibs.rsp

gtp4给出的解释是这样的:

连接器(linker)被指令以特定的方式处理静态库和生成的输出。这不仅仅关于链接gtest.a。让我们逐一分析参数:

  1. -Wl,--whole-archive CMakeFiles/test_print_hello_world.dir/objects.a -Wl,--no-whole-archive: 这一段指示连接器将指定的静态库(objects.a)中所有的目标文件全部加入到最终的可执行文件中。--whole-archive 选项强制链接器不忽略任何目标文件,哪怕它们看起来并没有被使用。这通常用来确保库中可能会被程序运行时动态引用的对象都将被包含进来。
  2. -o test_print_hello_world.exe: 这指示生成的输出是一个名为 test_print_hello_world.exe 的可执行文件。
  3. -Wl,--out-implib,libtest_print_hello_world.dll.a: 这段指示连接器创建一个导入库(import library),名字叫做 libtest_print_hello_world.dll.a。在Windows平台,当你创建一个DLL的时候,你通常也会生成一个关联的导入库,它用于从DLL中链接函数。即使你的意图是创建一个可执行文件,连接器也可以生成这样一个导入库,它可以被其他的DLL或可执行文件使用,来链接到你的程序(尽管这在实际中并不常见)。

后缀.dll.a是在MinGW或Cygwin环境中使用的,它表示这是一个用于链接DLL的导入库。与.lib文件相比(通常在Native Windows环境中用作导入库),.dll.a 的格式略有不同,以符合GCC工具链的预期。

如果你的目标确实是生成一个独立的可执行文件,你可能不需要 --out-implib 参数,除非你打算将你的可执行程序输出一些接口给其他程序动态链接使用。只有在生成DLL时,--out-implib 通常才是必要的。

如果有进一步的混淆,你可以检查CMakeList.txt中的设置,或者是和其他库或目标的交互方式,来确定为什么这个命令行被这样配置。这可能需要你具体了解项目的构建系统配置。

这篇关于【问题记录】c++编译报错~/bin/ld.exe: cannot find 0的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/951007

相关文章

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工