×

g如何编译不通目录下的文件

g如何编译不通目录下的文件(编译得到的目标文件为什么不能直接运行)

admin admin 发表于2023-03-24 18:16:09 浏览50 评论0

抢沙发发表评论

本文目录一览:

LINUX中GCC编译器如何不同目录下的C程序

$cd ~

$cd C_code

$gcc xxxx.c -o xxxxxxxx

其中,~就是 /home/a564034199

xxxx就是你的源文件的名字

xxxxxxxx就是要编译的文件

头文件和源文件在不同的目录下,该怎么编译

书写头文件时用 冒号,连带写上路径。

例如:

#includestdio.h

#include "K:\Quan\Sir\P1\my.h"

-----

编译命令行 加入 搜索路径, 例如 VC++ 6.0

CL /I "K:\\Quan\\Sir\\P1" xyz.c

gcc如何编译多文件?

你这里有几处问题。

fun.h 加头文件卫士,头文件中声明全局变量要用static修饰。

#ifndef FUN_H

#define FUN_H

static int g=10;

 void fun();

#endif

其他文件中引用这个文件的变量,extern int g;

mian.c

#includestdio.h

#include"fun.h"

extern int g;

 void main()

{

    printf("%d\n",g++);

    fun(); 

}

makefile怎么编译所有目录下的.o

在Makefile中,可以使用通配符来编译所有目录下的.o文件。使用通配符有两种方法:

方法一:使用通配符指定所有要编译的.o文件

plaintext

Copy code

OBJ_DIR = obj

SRC_DIRS = src1 src2 src3

# 获取所有目录下的.c文件

SRCS = $(foreach dir,$(SRC_DIRS),$(wildcard $(dir)/*.c))

# 将所有.c文件编译成.o文件

OBJS = $(patsubst %!c(MISSING),$(OBJ_DIR)/%!o(MISSING),$(notdir $(SRCS)))

# 定义编译规则

$(OBJ_DIR)/%!o(MISSING): $(SRCS)

$(CC) $(CFLAGS) -c $ -o $@

# 定义默认目标

all: $(OBJS)

# 清空目标文件

clean:

rm -f $(OBJ_DIR)/*.o

方法二:使用目录变量遍历所有目录并编译.o文件

plaintext

Copy code

OBJ_DIR = obj

SRC_DIRS = src1 src2 src3

# 设置目录变量

vpath %!c(MISSING) $(SRC_DIRS)

# 获取所有.c文件的.o文件名称

OBJS = $(patsubst %!c(MISSING),$(OBJ_DIR)/%!o(MISSING),$(notdir $(wildcard $(addsuffix /*.c,$(SRC_DIRS)))))-g如何编译不通目录下的文件

# 定义编译规则

$(OBJ_DIR)/%!o(MISSING): %!c(MISSING)

$(CC) $(CFLAGS) -c $ -o $@

# 定义默认目标

all: $(OBJS)

# 清空目标文件

clean:

rm -f $(OBJ_DIR)/*.o

以上两种方法都可以编译所有目录下的.o文件。具体选择哪种方法取决于项目的需求和个人偏好。

怎么用gcc编译文件?

在终端中输入 gcc 文件名 -o 目标文件名

然后 ./目标文件名 就行了,没有目标文件名,自动存为 a

执行 ./a 就行了。

在使用Gcc编译器的时候,我们必须给出一系列必要的调用参数和文件名称。GCC编译器的调用参数大约有100多个,其中多数参数我们可能根本就用不到,这里只介绍其中最基本、最常用的参数。

GCC最基本的用法是∶gcc [options] [filenames]

其中options就是编译器所需要的参数,filenames给出相关的文件名称。

-c,只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程序的子程序文件。

-o output_filename,确定输出文件的名称为output_filename,同时这个名称不能和源文件同名。如果不给出这个选项,gcc就给出预设的可执行文件a.out。

-g,产生符号调试工具(GNU的gdb)所必要的符号资讯,要想对源代码进行调试,我们就必须加入这个选项。

-O,对程序进行优化编译、连接,采用这个选项,整个源代码会在编译、连接过程中进行优化处理,这样产生的可执行文件的执行效率可以提高,但是,编译、连接的速度就相应地要慢一些。

-O2,比-O更好的优化编译、连接,当然整个编译、连接过程会更慢。

-Idirname,将dirname所指出的目录加入到程序头文件目录列表中,是在预编译过程中使用的参数。C程序中的头文件包含两种情况∶

A)#include myinc.h

B)#include “myinc.h”

其中,A类使用尖括号( ),B类使用双引号(“ ”)。对于A类,预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻相应的文件,而B类,预处理程序在目标文件的文件夹内搜索相应文件。 -g如何编译不通目录下的文件

GCC执行过程示例

示例代码 a.c:

#include stdio.h

int main()

{

printf("hello\n");

}

预编译过程:

这个过程处理宏定义和include,并做语法检查。

可以看到预编译后,代码从5行扩展到了910行。

gcc -E a.c -o a.i

cat a.c | wc -l

5

cat a.i | wc -l

910

编译过程:

这个阶段,生成汇编代码。

gcc -S a.i -o a.s

cat a.s | wc -l

59

汇编过程:

这个阶段,生成目标代码。

此过程生成ELF格式的目标代码。

gcc -c a.s -o a.o

file a.o

a.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped

链接过程:

链接过程。生成可执行代码。链接分为两种,一种是静态链接,另外一种是动态链接。使用静态链接的好处是,依赖的动态链接库较少,对动态链接库的版本不会很敏感,具有较好的兼容性;缺点是生成的程序比较大。使用动态链接的好处是,生成的程序比较小,占用较少的内存。-g如何编译不通目录下的文件

gcc a.o -o a

程序运行:

./a

hello

编辑本段

GCC编译简单例子

编写如下代码:

#include stdio.h

int main()

{

printf("hello,world!\n");

}

执行情况如下:

gcc -E hello.c -o hello.i

gcc -S hello.i -o hello.s

gcc -c hello.s -o hello.o

gcc hello.c -o hello

./hello

hello,world!