当前位置: 首页 > news >正文

makefile 参数和基本使用

make 常用选项

make[-f file] [options] [target]

make 默认在当前目录中查找GUNmakefile、makefile 及 Makefile 文件作为make的输入文件

-f 指定文件作为输入文件

-v 显示版本号

-n 只输出命令不执行, 一般作为测试

-s 执行命令不显示命令,

-w 显示执行前和执行后的路径

-C dir 指定makefile 所在的目录

gcc/g++编译流程

gcc–lstdc++ xxxx.cpp 直接从源代码得到可执行文件。

  1. 预处理 gcc –E xxx.cpp > xxx.i

  1. 编译 gcc –S xxx.i 得到名为 xxx.s 的汇编文件

  1. 汇编 gcc –c xxx.s 得到名为 xxx.o 的二进制文件

  1. 链接 gcc –lstdc++ xxx.o 得到 a.out 的可执行文件

makefile 中的变量

  • 系统变量

$* 不包括扩展名的目标文件名称

$+ 所有依赖文件,以空格分隔

$< 规则中的第一个条件

$? 所有时间戳比目标文件晚的依赖文件,以空格分隔

$@ 目标文件的完整名称

$^ 所有不重复的依赖文件,以空格分隔

$% 如果目标文件是归档成员,则该变量表示目标的归档成员名称

  • 系统常量(make –p 查看)

AS 汇编文件的名称 默认as

CC C编译器名称 默认cc

CPP C预编译器名称 默认cc –E

CXX C++编译器名称 默认 g++

RM 文件删除程序名称 默认 rm -f

makefile 伪目标

伪目标: .PHONT: clean

声明目标为伪目标之后, makefile将不会判断目标是否存在或该目标是否需要更新

makefile 模式匹配

%.o:%.cpp .o依赖于对应的.cpp

Wildcard $(wilcard./*.cpp) 获取当前目录下所有的.cpp 文件

Patsubst $(patsubst%.cpp, %o, ./*.cpp) 将对应的.cpp文件替换成.o文件名

makefile 编译动态库

-fPIC 产生位置无关的代码

-shared 共享

-l(小L)指定动态库

-L 指定库文件搜索目录,默认只链接共享目录

-I(大i)指定头文件目录, 默认为当前目录

Makefile 通用部分作为公共头文件

Makefile中都是先展开所有变量再调用指令

= 赋值,使用最终值,不管变量调用写在赋值前还是赋值后,调用时都是取最终值。

:= 赋值 只受当前行及之前的代码影响。不会受后面的赋值影响。

举例:

1:

TARGET = a

OBJ = a.o b.o c.o

$(TARGET):$(OBJ)

$(CXX) $^ -O $@

%.o:%.cpp

gcc –c $^ -o $@

clean:

$(RM) $(TARGET) $(OBJ)

2: 精简

SOURCE=$(wilcard ./*.cpp ./.c)

OBJ=$(patsubst %.cpp,%.o, $(SOURCE)) #替换 .cpp-> .o

OBJ:= $(patsubst %.c,%.o, $(OBJ)) #替换 .c-> .o

.PHONY:clean

$(TARGET):$(OBJ)

$(CXX) $^ -O $@

clean:

$(RM) $(TARGET) $(OBJ)

3:ARM

RM = rm

CC =arm-xilinx-linux-gnueabi-gcc

CPP =arm-xilinx-linux-gnueabi-g++

AR =arm-xilinx-linux-gnueabi-ar

# target library

TGT_NAME = xxxx

ROOTDIR = ../

BINDIR = bin

TARGET =./$(TGT_NAME)

#

# Dependency List

#

MODULES = $(wildcard *.c)

CDBGFMT = -gdwarf-2

CFLAGS = -Wall

INCLUDES = -I"../include"

LIBRARYS = -lxxx

LIBPATH = -L../lib

CFLAGS += -DDEBUG -O0 $(CDBGFMT)

CFLAGS += $(INCLUDES)

OBJECTS = $(MODULES:.c=.o)

.SUFFIXES: .c

.c.o:

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

$(TARGET): $(OBJECTS)

$(CC) -o $(TARGET)$(OBJECTS) $( LIBRARYS) $( LIBPATH)

clean:

$(RM) -rf ./*.o

$(RM) -rf ./$(TARGET)

http://www.lryc.cn/news/37556.html

相关文章:

  • golang 占位符还傻傻分不清?
  • manacher算法详解
  • 要做一个关于DDD的内部技术分享,记录下用到的资源,学习笔记(未完)
  • KDZD互感器二次负载测试仪
  • 在空投之后,Blur能否颠覆OpenSea的主导地位?
  • 2023年新三板产品及服务研究报告
  • 张力控制之开环模式
  • python的django框架从入门到熟练【保姆式教学】第二篇
  • 解决win10的过度保护导致文件下载不了程序不能打开运行
  • 扬帆优配|业务量大突破,这个行业发展明显向好
  • DJ1-4 计算机网络和因特网
  • Nginx根据$host及请求的URI规则重定向rewrite
  • 人工智能实验一:使用搜索算法实现罗马尼亚问题的求解
  • Spring Security基础入门
  • dnsresolver-limit
  • 使用 YoctoProject集成Qt6
  • 「媒体邀约」如何选择适合的媒体公关,媒体服务供应商
  • html2canvas和jspdf导出pdf,每个页面模块占一页,在pdf中垂直居中显示
  • 数学小课堂:集合论的公理化过程(用构建公理化体系的思路来构建自然数)
  • 3.10多线程
  • 缓存双写一致性之更新策略探讨
  • scala高级函数快速掌握
  • 手写模拟SpringMvc源码
  • 五分钟了解JumpServer V2.* 与 v3 的区别
  • 用友开发者中心应用构建实践指引!
  • snap使用interface:content的基础例子
  • 蓝桥杯刷题第七天
  • FinOps首次超越安全成为企业头等大事|云计算趋势报告
  • 【深度强化学习】(3) Policy Gradients 模型解析,附Pytorch完整代码
  • Windows基于Nginx搭建RTMP流媒体服务器(附带所有组件下载地址及验证方法)