Makefile 使用小结
Makefile的基本格式
#目标:依赖(条件)
# 命令
#all: add.c sub.c dive.c mul.c main.c
# gcc add.c sub.c div.c mul.c main.c -o app
app:add.o sub.o dive.o mul.o main.o
gcc add.o sub.o
add.o:add.c
gcc -c add.c gcc -c 只编译,不链接
sub.o:sub.c
gcc -c sub.o
dive.o:dive.c
gcc -c dive.c
Makefile 执行的两个阶段:
第一个阶段,自上向下建立关系树
第二个阶段, 自下向上执行命令
-------------------------------------------------
Makefile 项目管理工具
节省项目编译时间
只编译已经修改的文件
一次编写 终身受益
程序运行出错的返回值都会保存在$?里面,可以通过
echo $?来查看
1.调用make命令来调用Makefile文件,当敲make会自动到当前目录下找Makefile
2.在Makefile里面#代表注释
3. 所有命令前面必须有一个TAB空格键
4. 如果这个目标不依赖任何文件,则在定义目标之后,可以直接跟命令
clean:
rm *.o
rm app
5. make时候如果不带任何参数,则默认会执行第一个目标, 如果想执行clean目标,则需要手动指定clean目标:make clean (如果当前目录下已经存在clean文件,则不再执行clean命令)
解决办法:可以声明一个伪目标
.PHONY:clean
clean:
rm -f *.o
rm -f app
6. 如果想让Makefile 在执行命令出错的时候,不退出,则需要在命令前面加上’’-’’,如:
- rm add.o
所以完整写法为:
-rm -f *.o
-rm -f app
7. 如果不想看到Makefile输出的命令,可以在命令前面加上”@”符号
test:
@echo “hello”
8. Makefile中还可以定义变量,当要引用变量时候,可以$(变量名)来引用
obj=add.o sub.o mul.o dive.o main.o
app:$(obj)
gcc $(obj) -o app
9. Makefile有内建语法规则,make -P
$@表示目标, $^表示所有依赖, $<表示依赖中的第一个
#如果遇到后缀名为.o的文件,就依赖于同名的后缀名为.c的文件
%.o:%.c
gcc -c $< -o $@
#wildcard 可以打到当前目录下所有以.c结尾的文件名
src = $(wildcard *.c);
#patsubst 是一个字符串替换函数,意思就是说要把$(src)变量里面所有的以.c结尾的文件替换成.o结尾的文件(注意!只是文件名替换,没有生成.o文件);
obj = $(patsubst %.c,%.o,$(src));
target = app
$(target):$(obj)
gcc $^ -o $@
10. Makefile 常用变量(增加编译时的调试标志)
#预处理器标志(头文件)
CPPFLAGS= -Iinclude
# 编译的时候是否需要加调试信息
CFLAGS= -g -Wall
# 指定编译时的共享库
LDFLAGS= -L../lib -lmycalc
# 指定编译器
CC=gcc
$(CC) -c $< $(CFLAGS) $(CPPFLAGS) -o $@
11.
#彻底清除生成过程文件和生成配置文件
distclean:
install:
12 make -C 进入指定目录,调用里面的Makefile
make -C src
进入src这个目录,调用src目录里面的Makefile
Makefile 使用小结的更多相关文章
- makefile学习小结
=============2016/08/15================ 上午完成makefile的试验,缩短了代码量,现在make强大,有缺省的变量,能自己推导关系,不需要gcc –MM -M ...
- makefile实验四 编译本地的源文件 + 变量的高级主题一
<一>编译本地的源文件 + 变量的模式替换 实验代码 root@ubuntu:~/Makefile_Test/5make_test# vim makefile target := t ...
- 《UNIX环境高级编程》笔记——3.文件IO
一.引言 说明几个I/O函数:open.read.write.lseek和close,这些函数都是不带缓冲(不带缓冲,只调用内核的一个系统调用),这些函数不输入ISO C,是POSIX的一部分: 多进 ...
- Makefile小结
Makefile最基本的规则:target....:prerequisites..... command 或:target....:prerequisites.....;command target: ...
- Solaris 命令 小结
Solaris 命令 小结 prstat -a 系统进程监控 Solaris 10默认的shell是sh,可以改成bash #useradd -m -d /home/dave dave -s /bin ...
- 高通平台 lcd driver 调试小结
一.概述 1.1 简介 本文档主要包括LCD模块的驱动流程分析.Framebuffer相关知识.Gralloc等相关内容,以及LCD调试的一些经验和相关bug的分析和讲解. 1.2 开发环境 And ...
- 十天学Linux内核之第十天---总结篇(kconfig和Makefile & 讲不出再见)
原文:十天学Linux内核之第十天---总结篇(kconfig和Makefile & 讲不出再见) 非常开心能够和大家一起分享这些,让我受益匪浅,感激之情也溢于言表,,code monkey的 ...
- tiny210——uboot移植Makefile文章分析
这东西已经写,我们没有时间发布,如今,终于有时间稍微长送记录汇总uboot学习过程.具体了.以后忘了也能够再温习回来嘛有些特殊字符显示得乱掉了 Makefile追踪技巧: 技巧1:能够先从编译目标開始 ...
- LLVM小结
随笔- 5 文章- 0 评论- 10 LLVM小结 如果说gcc是FSF的传奇,llvm就是Chris Lattner的小清新.当然啦,想具体看看这位四处游山玩水还GPA 4.0的大神和他的 ...
随机推荐
- Pycharm 2018 激活 亲测有效
下载 https://share.weiyun.com/5NVc5U3 并将 JetbrainsCrack-3.1-release-enc.jar 放置到 pycharm安装目录的\bin目录下( ...
- WebSocket原理分析
Web应用的通信过程通常是客户端通过浏览器发出一个请求,服务器端接收请求后进行处理并返回结果给客户端,客户端浏览器将信息呈现.这种机制对于信息变化不是特别频繁的应用可以良好支撑,但对于实时要求高.海量 ...
- uva 10518 - How Many Calls?(矩阵快速幂)
题目链接:uva 10518 - How Many Calls? 公式f(n) = 2 * F(n) - 1, F(n)用矩阵快速幂求. #include <stdio.h> #inclu ...
- RS特殊报表样式需求处理
收到一朋友求助:如下图的报表格式 思路如下 第一步:处理出基础数据是每个用户每个月属于每个区间的数据savemoney_bymonthmonth user save_qujian201412 a1 5 ...
- RS开发日期提示控件默认为昨天之进阶篇
时隔<RS开发日期提示控件默认为昨天>这篇博文已经很久了,请原谅我隔了这么久才继续来写这篇笔记.也希望读到这篇笔记的朋友可以从这篇笔记中学习到一些关于RS日期控件和JS的一些应用知识,当然 ...
- 在ubuntu下如何搜索文件?
来自 1.whereis 文件名 特点:快速,但是是模糊查找,例如 找 #whereis mysql 它会把mysql,mysql.ini,mysql.*所在的目录都找出来.我一般的查找都用这条命令. ...
- OPENERP 构建动态视图
来自:http://shine-it.net/index.php/topic,16142.0.html 在openerp展示界面通常是通过定义class的view(xml文件)来实现的. 有时这种方法 ...
- java面试题(开发框架)
博客分类: java基础 面试Java多线程编程设计模式 java基础面试题目,以备不时之需 俗话说 细节决定成败. 就算很简单,很小的问题,我们还是要注意一下的. ...
- 数据库如何创建视图create view
数据库如何创建视图 创建视图的理想步骤: 一般来说,视图创建可以分为五步走: 第一步:先考虑select语句的编写.我们知道,视图其实就是一个select语句的集合,所以,我们建立视图的第一步 ...
- 【laravel5.4】DB::table的操作
基于laravel5.4版本的查询构造器的简单几个操作:(相对于TP3.2版本) //获取指定多行多列,二维,,对象 [select] $names = ''; $names = DB::table( ...