• 开始编写Makefile(二)Makefile变量的使用


    1. Makefile可以使用变量代替

    命令行:make -f Makefile2 说明开始make一个名为Makefile2的文件

    ###############定义变量##################
    CC:=gcc
    CFLAGS:=-Iinclude
    CFLAGS+= -c
    TARGET:=bin/mymath_test
    DEPEND:=obj/mymath.o
    DEPEND+=obj/mymath_test.o
    
    $(TARGET):$(DEPEND)
    	$(CC) -o $@ $^
    obj/mymath.o:src/mymath.c
    	$(CC) -o $@ $(CFLAGS) $^
    obj/mymath_test.o:src/mymath_test.c
    	$(CC) -o $@ $(CFLAGS) $^
    clean:
    	rm -rf $(TARGET) $(DEPEND)
    	cd ..
    

      其中下面 目标:=依赖列表 都是变量定义

    CC:=gcc
    CFLAGS:=-Iinclude
    CFLAGS+= -c
    TARGET:=bin/mymath_test
    DEPEND:=obj/mymath.o
    DEPEND+=obj/mymath_test.o

    第二:

    $@ 表示当前目标文件

    $^表示当前要目标要依赖的全部文件

    1. 常见的虚目标

    主要说明clearn这个虚目标

    make -f Makefile2 clean 表示清除刚才make编译好的文件;就是说删除刚才编译好的可执行文件和目标.o的文件

    clean:
    	rm -rf $(TARGET) $(DEPEND)
    	cd ..
    daokr@ubuntu:/mnt/hgfs/mystudy/clession10$ make -f Makefile2
    gcc -o obj/mymath.o -Iinclude -c src/mymath.c
    gcc -o obj/mymath_test.o -Iinclude -c src/mymath_test.c
    gcc -o bin/mymath_test obj/mymath.o obj/mymath_test.o
    daokr@ubuntu:/mnt/hgfs/mystudy/clession10$ make -f Makefile2 clean
    rm -fr bin/mymath_test obj/mymath.o obj/mymath_test.o
    

      

    ###############定义变量##################
    CC:=gcc
    CFLAGS:=-Iinclude
    CFLAGS+= -c
    TARGET:=bin/mymath_test
    DEPEND:=obj/mymath.o
    DEPEND+=obj/mymath_test.o
    
    $(TARGET):$(DEPEND)#开始执行
    	$(CC) -o $@ $^
    obj/mymath.o:src/mymath.c
    	$(CC) -o $@ $(CFLAGS) $^
    obj/mymath_test.o:src/mymath_test.c
    	$(CC) -o $@ $(CFLAGS) $^
    .PHONY:clean#指定clean是虚目标
    clean:
    	rm -fr $(TARGET) $(DEPEND)
    

      

  • 相关阅读:
    Hit Event 击中碰撞
    基于ReentrantLock通知唤醒的生产消费模式
    spring 源码构建
    读写分离、分库、分表
    python 反射的使用
    基础算法
    git 命令使用
    java设计模式应用
    linux 中python的使用
    linux命令
  • 原文地址:https://www.cnblogs.com/wanglijun/p/8643464.html
Copyright © 2020-2023  润新知