- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我使用 clang 而不是 gcc 编译了一个 GTK+ 程序。到目前为止一切顺利,只是我不能正确地建立 ld 链接。
调用 gcc 的原始 makefile 进行链接,如下所示:
gcc -g -O2 -export-dynamic -o my_application somefile.o another.o -pthread -lgnomeui-2 -lSM -lICE -lbonoboui-2 -lgnomevfs-2 -lgnomecanvas-2 -lgnome-2 -lpopt -lbonobo-2 -lbonobo-activation -lORBit-2 -lart_lgpl_2 -lgconf-2 -lglade-2.0 -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfreetype -lfontconfig -lgobject-2.0 -lgmodule-2.0 -lgthread-2.0 -lrt -lglib-2.0 -lxml2 -pthread -lgstreamer-0.10 -lgobject-2.0 -lgmodule-2.0 -lxml2 -lgthread-2.0 -lrt -lglib-2.0
如果我在上面的命令中简单地将 gcc 替换为 clang ,我会从后者收到此警告:
clang: warning: argument unused during compilation: '-e xport-dynamic'
问题是:clang 无法将“-export-dynamic”识别为链接器选项,因此不会将其传递给 ld。这会导致对外部函数的引用被废弃:当执行最终二进制文件时,菜单选项和按钮都没有反应。
如果我使用 gcc 执行最后的链接步骤,则二进制文件可以完美运行(即使它实际上是使用 clang 编译的,而 gcc 仅执行链接)。因为我试图在我的机器上用 clang 完全替换 gcc,所以这是 Not Acceptable 。
所以我尝试了这个:
ld /usr/lib/crt1.o /usr/lib/crti.o /usr/lib/crtn.o -g -O2 -export-dynamic my_application somefile.o another.o -o -lgnomeui-2 -lSM -lICE -lbonoboui-2 -lgnomevfs-2 -lgnomecanvas-2 -lgnome-2 -lpopt -lbonobo-2 -lbonobo-activation -lORBit-2 -lart_lgpl_2 -lgconf-2 -lglade-2.0 -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfreetype -lfontconfig -lgobject-2.0 -lgmodule-2.0 -lgthread-2.0 -lrt -lglib-2.0 -lxml2 -lgstreamer-0.10 -lgobject-2.0 -lgmodule-2.0 -lxml2 -lgthread-2.0 -lrt -lglib-2.0
通过添加前 3 个对象,我避免了“找不到 _start”消息。但后来我收到了上述两个投诉:
/usr/lib/crt1.o: In function
_start
: (.text+0x12): undefined reference to__libc_csu_fini
/usr/lib/crt1.o: In function_start
: (.text+0x19): undefined reference to__libc_csu_init
我尝试在列表中添加 crtbegin.o 和 crtend.o,甚至在 crt1.o 之前,但无济于事。链接器的正确调用是什么?
(编辑后):如果没有其他工作,有没有办法在 gcc 时捕获 gcc 传递给 ld 的确切参数用于链接?
最佳答案
gcc
自动将语言支持库和对象添加到您提供的链接列表中。如果你想直接调用 ld
,你必须自己添加它们。以man ld
为例,可以是
ld -o <output> /lib/crt0.o hello.o -lc
尝试添加-lc
,您需要的符号应该在其中(至少在我的系统上是这样)。
关于c - ld 提示 : in function "_start", undefined reference to "__libc_csu_fini"& "__libc_csu_init",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10280631/
我在玩 GDB 的 rbreak . 时首先注意到它,然后做了一个最小的例子: (gdb) file hello_world.out Reading symbols from hello_world.
在linux _start()中是触发main()函数的汇编函数。 Windows 中有什么?我不确定我的问题是对还是错? 实际上我正在尝试在 Linux 中使用 _start() - 工作正常。但是
我有一个 elf64 可执行文件 foo,我想“手动”加载和启动它并能够从中调用其他函数。我如何将它加载到内存中,然后设置指令指针与它一起运行。 foo 不是一个共享对象库,它是一个可执行文件,具有像
我在 gcc 上编译的 c 代码给出了错误 Cannot find entry symbol _start defaulting to 00000 .谁能告诉我为什么以及如何纠正它? 命令行是 arm
我正在阅读一本描述加载程序如何工作的教科书: When the loader runs, it copies chunks of the executable object file into the
请帮助我使用 arm926ejs cpu 的 gnu 汇编程序。 我尝试构建一个简单的程序(test.S): .global _start _start: mov r0, #2 bx
我尝试将代码不放在主函数中,而是直接放在 _start 中: segment .text global _start _start: push rbp mov rbp,
当我汇编以下汇编代码时,出现错误 Segmentation fault (core dumped) section .text global _start _start: mov eax, 8
我正在 64 位 Linux 中构建没有 glibc 的简单应用程序。但我不知道如何获取参数。 我用谷歌搜索,发现 RDI 是 argc,RSI 是 argv。但它没有用。 当 _start 函数开始
'$' 后跟一个标识符是什么意思? x86 汇编,AT&T 语法。 最佳答案 在 AT&T 语法中 $意味着将后面的内容视为立即常量而不是内存地址。换句话说, movl $_start, %eax 加
在过去的几天里,我一直试图了解当我们执行一个 C 程序时幕后会发生什么。然而,即使在阅读了大量帖子后,我也找不到详细而准确的解释。有人可以帮我吗? 最佳答案 在编译和链接程序时,您通常会为特定用途找到
您好,我制作了一个简单的 hello world C 程序,我正在这样编译它: gcc -c hello.c ld hello.o -lc -o out 我从 ld 收到警告:ld : _start
我在我的应用程序中使用 Asp.Net MVC-4。我创建了一个 Controller ,例如 Person,在这个 Controller 中我有 3 个 Actions,例如 GetName、Get
我正在学习汇编编程。下面是打印“Hello, World!”的简单程序。当程序完美运行时,我收到警告消息,而 loading ld: warning: cannot find entry symbol
我一直在阅读 ELF 规范,但无法弄清楚程序入口点和 _start 地址从何而来。 看起来他们应该在一个非常一致的地方,但我做了一些琐碎的程序,_start 总是在不同的地方。 谁能澄清一下? 最佳答
这个问题在这里已经有了答案: Assembling 32-bit binaries on a 64-bit system (GNU toolchain) (2 个答案) 关闭 6 年前。 我试着在没
我试着写了一个makefile: CC = g++ LD = ld CFLAGS = -Wall -std=c++0x -O3 LDFLAGS = -lgsl -lgslcblas -lpth
我从同事那里收到了我的程序(在 RHEL 5.3 上运行的 qt 应用程序)的回溯,在分析它时我发现了一些我无法解释的东西。如果查看此回溯,您会注意到 main 和 _start 的跟踪。但在此之前,
我写了一个简单的 c 程序,并尝试使用 GDB 来调试程序。我了解在主要功能中使用以下内容: 进入时 push %ebp mov %esp,%ebp 退出时 leave ret 然后我在 _
我已经编译了一个fortran文件并创建了一个目标文件。之后我尝试执行目标文件但出现错误。操作系统是Ubuntu,错误如下: 编译源文件 gfortran -O3 reader.f iotools.c
我是一名优秀的程序员,十分优秀!