Har*_*rma 3 c linux gcc linux-kernel
我是 Linux 编程的新手,是从Michael Kerrisk 的 The Linux Programming Interface 中学习的。
我必须编译我的第一个具有依赖项的程序。
目录结构:
--linux-programs
|--seek_io.c
|--lib
|--tlpi_hdr.h
|--error_functions.h
|--error_functions.c
|--get_num.h
|--ename.c.inc
Run Code Online (Sandbox Code Playgroud)
我想编译seek_io.c程序,在lib目录下有依赖项,这样我就可以看到程序是如何工作的。
我尝试了一些东西,对于它们如何在这个stackoverflow 答案之后工作完全一无所知。我遇到了各种各样的错误,因为我是 Linux 编程的绝对初学者,而不是编程、linux OS 和 C。
试炼:
gcc -I ./lib/ -c ./lib/error_functions.c然后gcc -o seek_io.c ./error_function.o给出错误:
/usr/lib/gcc/x86_64-linux-gnu/crt1.o: In function _start:
(.text+0x20): undefined reference to main
collect2: error: ld returned 1 exit status
这次运行后,ls我发现我seek_io.c的没有列出。
基本上这本书的作者对tlpi_hdr.h文件说:
该头文件包括许多示例程序使用的各种其他头文件,定义了布尔数据类型,并定义了用于计算两个数值的最小值和最大值的宏。使用这个头文件可以让我们的示例程序更短一些。
链接到上述文件的代码:
问题在于您的第二个gcc命令,您使用该-o文件指定输出文件存储生成的可执行文件的位置,但将 C 源文件的名称传递给它seek_io.c...
gcc -o seek_io.c ./error_function.o
Run Code Online (Sandbox Code Playgroud)
这意味着链接文件error_function.o并将可执行文件存储在seek_io.c. 这将失败,因为没有main独立可执行文件所需的函数,因此您的 C 源文件不会被失败的链接命令覆盖。
您可以通过向-o选项传递正确的输出文件名来轻松解决此问题,在这种情况下(此链接命令)应该是您要创建的可执行文件的名称,例如seek_io:
gcc -o seek_io seek_io.c ./error_function.o
Run Code Online (Sandbox Code Playgroud)
(但是如果没有-I ./lib/,这将失败,因为seek_io.c包含tlpi_hdr.h在该目录中。如果您将其添加到该命令中,它应该可以工作。)
您还可以决定将编译和链接步骤分为两个单独的步骤(上面的命令将编译 seek_io.c成一个目标文件,然后将两个目标文件链接成一个可执行文件):
$ gcc -I ./lib/ -c ./lib/error_functions.c
$ gcc -I ./lib/ -c seek_io.c
$ gcc -o seek_io seek_io.o error_function.o
Run Code Online (Sandbox Code Playgroud)
最后一个挑剔是,对于-I指定搜索包含文件的目录的标志,更常见的用法是在标志本身和目录名称之间没有空格,因此您最常见的-I./lib是-Ilib.
$ gcc -Ilib -c ./lib/error_functions.c
$ gcc -Ilib -c seek_io.c
$ gcc -o seek_io seek_io.o error_function.o
Run Code Online (Sandbox Code Playgroud)