gcc如何编译多文件?

gcc如何编译多文件?,第1张

你这里有几处问题。

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

#ifndef FUN_H

#define FUN_H

static int g=10

 void fun()

#endif

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

mian.c

#include<stdio.h>

#include"fun.h"

extern int g

 void main()

{

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

    fun() 

}

在终端中输入 gcc 文件名 -o 目标文件名\x0d\x0a然后 ./目标文件名 就行了,没有目标文件名,自动存为 a\x0d\x0a执行 ./a 就行了。\x0d\x0a\x0d\x0a在使用Gcc编译器的时候,我们必须给出一系列必要的调用参数和文件名称。GCC编译器的调用参数大约有100多个,其中多数参数我们可能根本就用不到,这里只介绍其中最基本、最常用的参数。\x0d\x0aGCC最基本的用法是∶gcc [options] [filenames]\x0d\x0a其中options就是编译器所需要的参数,filenames给出相关的文件名称。\x0d\x0a-c,只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程序的子程序文件。\x0d\x0a-o output_filename,确定输出文件的名称为output_filename,同时这个名称不能和源文件同名。如果不给出这个选项,gcc就给出预设的可执行文件a.out。\x0d\x0a-g,产生符号调试工具(GNU的gdb)所必要的符号资讯,要想对源代码进行调试,我们就必须加入这个选项。\x0d\x0a-O,对程序进行优化编译、连接,采用这个选项,整个源代码会在编译、连接过程中进行优化处理,这样产生的可执行文件的执行效率可以提高,但是,编译、连接的速度就相应地要慢一些。\x0d\x0a-O2,比-O更好的优化编译、连接,当然整个编译、连接过程会更慢。\x0d\x0a-Idirname,将dirname所指出的目录加入到程序头文件目录列表中,是在预编译过程中使用的参数。C程序中的头文件包含两种情况∶\x0d\x0aA)#include \x0d\x0aB)#include “myinc.h”\x0d\x0a其中,A类使用尖括号(),B类使用双引号(“ ”)。对于A类,预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻相应的文件,而B类,预处理程序在目标文件的文件夹内搜索相应文件。 \x0d\x0a\x0d\x0aGCC执行过程示例\x0d\x0a\x0d\x0a示例代码 a.c:\x0d\x0a#include \x0d\x0aint main()\x0d\x0a{\x0d\x0aprintf("hello\n")\x0d\x0a}\x0d\x0a预编译过程:\x0d\x0a这个过程处理宏定义和include,并做语法检查。\x0d\x0a可以看到预编译后,代码从5行扩展到了910行。\x0d\x0agcc -E a.c -o a.i\x0d\x0acat a.c | wc -l\x0d\x0a5\x0d\x0acat a.i | wc -l\x0d\x0a910\x0d\x0a编译过程:\x0d\x0a这个阶段,生成汇编代码。\x0d\x0agcc -S a.i -o a.s\x0d\x0acat a.s | wc -l\x0d\x0a59\x0d\x0a汇编过程:\x0d\x0a这个阶段,生成目标代码。\x0d\x0a此过程生成ELF格式的目标代码。\x0d\x0agcc -c a.s -o a.o\x0d\x0afile a.o\x0d\x0aa.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped\x0d\x0a链接过程:\x0d\x0a链接过程。生成可执行代码。链接分为两种,一种是静态链接,另外一种是动态链接。使用静态链接的好处是,依赖的动态链接库较少,对动态链接库的版本不会很敏感,具有较好的兼容性;缺点是生成的程序比较大。使用动态链接的好处是,生成的程序比较小,占用较少的内存。\x0d\x0agcc a.o -o a\x0d\x0a程序运行:\x0d\x0a./a\x0d\x0ahello\x0d\x0a编辑本段\x0d\x0aGCC编译简单例子\x0d\x0a\x0d\x0a编写如下代码:\x0d\x0a#include \x0d\x0aint main()\x0d\x0a{\x0d\x0aprintf("hello,world!\n")\x0d\x0a}\x0d\x0a执行情况如下:\x0d\x0agcc -E hello.c -o hello.i\x0d\x0agcc -S hello.i -o hello.s\x0d\x0agcc -c hello.s -o hello.o\x0d\x0agcc hello.c -o hello\x0d\x0a./hello\x0d\x0ahello,world!

CC= gcc

CFLAGS= -O2 -g -Wall

LIBS= -lsqlite3

LIB_DIR= -L../sqlite3/lib/

INCLUD_DIR= -I../sqlite3/include

test:test.c

$(CC) $^ $(CFLAGS) -o $@ \

$(LIBS) $(INCLUD_DIR) $(LIB_DIR)

.PHONY:clean

clean:

-rm test

1.解释:编译器是gcc(可选)

2.CFLAGS= -O2 -g -Wall 是gcc的参数 -O2优化,-g 加调试信息, -Wall(警告)---CFLAGS项可选

3.LIBS= -lsqlite3(库名)有就写没有就不要写,一般的库编译器自己去系统找,特殊的库要自己加。如:pthread线程库。

4.LIB_DIR= -L../sqlite3/lib/,指定库的路径

5.INCLUD_DIR= -I../sqlite3/include,指定头文件的路径.(I是大写的i)

6.

test:test.c

$(CC) $^ $(CFLAGS) -o $@ \

$(LIBS) $(INCLUD_DIR) $(LIB_DIR)

展开就是:gcc -O2 -g -Wall -o test -L../sqlite3/lib/ -I../sqlite3/include

针对你的问题:

先进你的A文件夹

all:test.o

cc *.o -I../B/include/(写绝对路径)

%*.o:%*.c


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11760345.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存