c++ 的makefile文件实例

 

首先声明, 感谢九哥的帮助,因为从来没写过makefile, 所以一直是手动编译,

然后有一次写了三个文件, 需要编译, 而我只编译了一个文件, 所以一直出错, 九哥告诉我用makefile更方便, 可以学习一下

于是我就写了看了很多的blog, 然后向九哥要了这么个东西, 据说还有可以生成的工具

###########################################
#Makefile for simple programs
###########################################
#INC 是你项目包含的目录
INC=
#LIB是你需要链接的库
LIB= -lpthread
#CC是一个变量名 可以随便起,这里代表你的编译器
CC=g++
#LINK是链接的程序
LINK=g++
#LDFLAGS是链接的选项
LDFLAGS=
#CC_FLAG 是编译选项
CC_FLAG=-Wall -m64

# PRG=操作符重载, 这里是目录名字
PRG=aa
# 这里是空格隔开, 不能是逗号,需要注意
# root@corleone:/opt/code/testC++/aa# ls
# makefile  mytime0.cpp  mytime.h  usertime0.cpp
# 上面这是目录下的文件, 那需要写几个.o的文件呢? 就这么写
OBJ=mytime0.o  usertime0.o


#当你make 后 编译器会去找 $(XXXX):$(xxxx) 的那一行
#你会发现它下面是一个 table缩进,  table缩进 表示要执行那个命令
#然后编译器会查看 "-o $@" 后面的目标有没有生成或者更新,没有就重新编译那个目标文件
#比如这里$(OBJ)是各种.o文件, 那么就会先编译这些.o文件 会去执行.cpp.o:下面的缩进命令

$(PRG):$(OBJ)
    $(CC) $(INC) $(LIB) -o $@ $(OBJ)

#.SUFFIXES表示后缀名
#这里表示要把INC下面的所有后缀是cpp或者c的编译成.o文件
.SUFFIXES: .c .o .cpp
.cpp.o:
    $(CC) $(CC_FLAG) $(INC) -c $*.cpp -o $*.o


.PRONY:clean
clean:
    @echo "Removing linked and compiled files......"
    rm -f $(OBJ) $(PRG)

 

###########################################
#Makefile for simple programs
###########################################
#INC 是你项目包含的目录
INC=
#LIB是你需要链接的库
LIB= -lpthread
#CC是一个变量名 可以随便起,这里代表你的编译器
CC=g++
#LINK是链接的程序
LINK=g++
#LDFLAGS是链接的选项
LDFLAGS=
#CC_FLAG 是编译选项
CC_FLAG=-Wall -m64

PRG=threadpooltest
OBJ=CThreadManage.o CThreadPool.o CThread.o CWorkerThread.o threadpooltest.o


#当你make 后 编译器会去找 $(XXXX):$(xxxx) 的那一行
#你会发现它下面是一个 table缩进,  table缩进 表示要执行那个命令
#然后编译器会查看 "-o $@" 后面的目标有没有生成或者更新,没有就重新编译那个目标文件
#比如这里$(OBJ)是各种.o文件, 那么就会先编译这些.o文件 会去执行.cpp.o:下面的缩进命令

$(PRG):$(OBJ)
    $(CC) $(INC) $(LIB) -o $@ $(OBJ)

#.SUFFIXES表示后缀名
#这里表示要把INC下面的所有后缀是cpp或者c的编译成.o文件
.SUFFIXES: .c .o .cpp
.cpp.o:
    $(CC) $(CC_FLAG) $(INC) -c $*.cpp -o $*.o


.PRONY:clean
clean:
    @echo "Removing linked and compiled files......"
    rm -f $(OBJ) $(PRG)



###########################################
#这里举个复杂的例子
###########################################

#1    先找到$(XXXX):$(xxxx)
#2    去找"-o $@" 后面的目标有没有生成或者更新,有就重新编译那个目标
#3    "-o $@" 后面所有的目标都好了就开始链接主程序了
#    编译和链接都需要一些选项
#4    >> output表示输出重定向到文件,这样出错了比较好查找
all_objs= xxx1.o ../xxx2.o ../../xxx3.o
#all_libs是链接的库, -L指定库的目录, -l指定库的名字
all_libs=-L../../sourceapp/qmarket/xykjclient/  -lMarketApi  -lACE
#$(target): $(all_objs)
#    $(LINK) $(LDFLAGS) -o $@ $(all_objs) $(all_libs) $(LIB) >> output

#你可以自己加一些选项 比如下面的test  你在命令行 执行 make test,他就会执行那个缩进的命令
test:
    @echo "this is test"
View Code

 

转载于:https://www.cnblogs.com/renfanzi/p/9213421.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Makefile是一种用于自动构建和管理程序的文件,它主要用于编译、链接和更新软件项目。在C语言开发中使用Makefile可以简化编译过程,提高开发效率。 Makefile文件由一系列规则组成,每个规则指定了文件的依赖关系和相应的编译命令。以下是一个简单的Makefile示例: ```makefile CC = gcc CFLAGS = -Wall -g all: myprogram myprogram: main.o utils.o $(CC) $(CFLAGS) -o $@ $^ main.o: main.c utils.h $(CC) $(CFLAGS) -c $< utils.o: utils.c utils.h $(CC) $(CFLAGS) -c $< clean: rm -f myprogram *.o ``` 在这个示例中,我们首先定义了编译器变量`CC`为`gcc`,编译选项变量`CFLAGS`为`-Wall -g`。然后定义了一个目标`all`,它依赖于目标`myprogram`。 `myprogram`目标依赖于`main.o`和`utils.o`两个目标,它通过`$(CC) $(CFLAGS) -o $@ $^`命令将这两个目标链接为可执行程序`myprogram`。 `main.o`目标依赖于`main.c`文件和`utils.h`头文件,它通过`$(CC) $(CFLAGS) -c $<`命令将`main.c`编译为目标文件`main.o`。 `utils.o`目标依赖于`utils.c`文件和`utils.h`头文件,它通过`$(CC) $(CFLAGS) -c $<`命令将`utils.c`编译为目标文件`utils.o`。 最后,我们定义了一个`clean`目标,用于清理生成的可执行文件和目标文件。 通过在命令行输入`make`命令,Make会自动查找Makefile文件并执行对应的规则,将源代码编译链接为可执行程序。如果某个文件发生了修改,Make会只重新编译修改的文件,从而提高编译效率。 总之,Makefile是一种强大的构建工具,可以帮助开发人员自动化编译和管理项目。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值