Make是一种工程管理器,其本质为管理多文件的一种工具。通常情况下,Make被用来编译源代码,其特点在于Make可以实现自动编译,所谓自动编译即根据文件的时间戳自动发现更新过的文件,以减少编译的工作量。通俗地说,即Make在编译代码时,只编译改动的文件,其他未改动且已经编译过的文件将不再编译,这大大缩短了编译的时间,提高了编译的效率。 Make工程管理器的核心文件为Makefile。Makefile中有3个关键的元素:目标(Target)、依赖(Dependency)、命令(Command)。
我的错误描述如上。 哎说到底是太年轻啊。 介绍一下我的文件: 三者的关系: main.c中调用了函数func,func.c中实现了函数func的功能,func.h中声明了封装函数func。
main.c
#include "func.h"
int main(int argc, const char *argv[])
{
func();
return 0;
}
func.c
void func(){
puts("hello world");
}
func.h
#ifndef _FUNC_H
#define _FUNC_H
void func();
#endif
首先说:第一个问题. 主要是因为你在使用编译命令gcc main.c -o main 时,他里面包含的func()这个函数在func.c文件中实现。所以在编译main.c时 他本身就是不完整的。一般这种情况下建议一起编译:即:gcc *.c -o main 这样就好了。
但是当我执行完上述命令后,又有新问题(炒) 什么问题呢,这个问题我搞了两天。首先声明我学过c语言。但是没有好好上linux的课,在写func.c时我直接抄了老师的ppt,我当时也疑惑为啥没有#include<stdio.h> ,我还自我安慰说linux和c语言肯定不一样,结果就是,简单错误折磨到死。
对没错,解决办法就是在func.c文件头部添加#include<stdio.h> 所以正确的func.c的代码:
#include <stdio.h>
void func(){
puts("hello world");
}
Makefile文件
main : main.o func.o #目标:依赖
gcc main.o func.o -o main #命令-指定依赖如何生成目标
main.o : main.c #.o文件依赖与.c文件
gcc -c main.c -o main.o #将.c文件生成.o文件
func.o : func.c
gcc -c func.c -o func.o
.PHONY:clean #伪目标,避免出现符号clean与文件clean重名的情况,导致执行make clean清除操作失败
clean:
rm *.o main
|