• gcc搜索头文件路径


    C和C++中include 搜索路径的一般形式以及gcc搜索头文件的路径
    注:-I 指定的目录,在使用尖括号引用时,是先于标准头文件目录被搜索的。例如使用了 -I./,且当前目录下有一个 stdio.h,那么在 #include <stdio.h>时,所引用的是当前目录下的stdio.h,而不是系统自带的标准头文件。
    C和C++中include 搜索路径的一般形式
    对于include 搜索的路径:
      C中可以通过 #include <stdio.h> 和 #include "stidio.h" ,区别是:
      在UNIX系统中,尖括号告诉编译器在一个或者多个标准系统目录中找到文件 /usr/include /usr/local/include;即系统头文件所在的目录。
      看看这些文件夹下是否有该头文件;如果没有,也不会检索当前文件所在路径,并将报错。
      使用双引号,编译器先到当前目录查找头文件或文件名中指定的其他目录,如果没找到在到标准系统目录查找。
      即,首先搜索本地目录,但是具体哪个目录依赖于编译器。有些编译器搜索源代码所在目录,有些则搜索当前目录,还有些搜索工程文件所在目录。当出现此类问题时,我们最好注意自己所用的编译器是如何操作的。在下面说明了gcc是如何操作的。
      同时,include也可以采用相对路径。比如,a.c需要/usr/local/include/Tleap/leap.h,而/usr/local/include是系统的默认搜索路径,所以在a.c中可以用相对路径包含,
      #include<Tleap/leap.h>。
      对于系统头文件,很多IDE具有标准搜索路径,IDE提供菜单选项用于指定使用尖括号时搜索的路径。
      查看GCC的搜索目录:(gcc --help)
      查看编译c++文件使用的头文件目录的命令为:`gcc -print-prog-name=cc1plus` -v
      查看编译c文件的头文件搜索目录的命令为 `gcc -print-prog-name=cc1` -v
    gcc寻找头文件的路径:
      1.在gcc编译源文件的时候,通过参数 -I 指定头文件的搜索路径,如果指定路径有多个路径时,则按照指定路径的顺序搜索头文件。
           命令形式如:“gcc -I /path/where/theheadfile/in sourcefile.c“,这里源文件的路径可以是绝对路径,也可以是相对路径。eg:设当前路径为/root/test,如果include_test.c要使用头文件“include/include_test.h“,有两种方法:
      1) include_test.c中#include “include/include_test.h”或者#include "/root/test/include/include_test.h",然后gcc include_test.c即可
      2) include_test.c中#include /include_test.h ,然后gcc –I include include_test.c也可
     2. 通过查找gcc的环境变量C_INCLUDE_PATH、CPLUS_INCLUDE_PATH、OBJC_INCLUDE_PATH来搜索头文件位置。
     3. 再找标准系统目录搜索,分别是
           /usr/include
           /usr/local/include
           /usr/lib/gcc-lib/i386-linux/2.95.2/include
         最后一行是gcc程序的库文件地址,各个用户的系统上可能不一样。
         gcc在默认情况下,都会指定到/usr/include文件夹寻找头文件。
         gcc还有一个参数:-nostdinc,它使编译器不再系统缺省的头文件目录里面找头文件,一般和 -I 联合使用,明确限定头文件的位置。在编译驱动模块 时,由于一些需求必须强制GCC不搜索系统默认路径,也就是不搜索/usr/include,这时就要用参数-nostdinc,还要自己用 -I 参数来指定内核头文件路径,这个时候在Makefile中指定即可。
      4. 当#include使用相对路径的时候,gcc最终会根据上面这些路径,来最终构建出头文件的位置。如#include 就是包含文件/usr/include/sys/types.h
     
    注:-I 指定的目录,在使用尖括号引用时,是先于标准头文件目录被搜索的。例如使用了 -I./,且当前目录下有一个 stdio.h,那么在 #include <stdio.h>时,所引用的是当前目录下的stdio.h,而不是系统自带的标准头文件。

  • 相关阅读:
    再探动态库的应用
    GNU Binutils
    ELF文件详解—初步认识
    解读linux的/proc下的statm、maps、memmap内存信息文件
    Linux重新编译内核
    查看进程的内存布局
    manjaro设置开机动画
    最常规的修复方式 通过live cd
    拯救manjaro桌面
    linux下的库入门
  • 原文地址:https://www.cnblogs.com/elseliving/p/7528853.html
Copyright © 2020-2023  润新知