通过实例介绍Linux编程中 Makefile的一些规则和用法

一、介绍
本文用实例介绍Makefile的一些使用规则和用法

二、一些用法

1. 宏定义使用

A:宏定义
-D DEBUG
-D DEBUG=[value]

CFLAGS=

hello world
1 + 9 = 10

CFLAGS=-D DEBUG

hello world
1 + 9 = 10
Debug is defined
Debug is defined as true


CFLAGS=-D DEBUG=1
hello world
1 + 9 = 10
Debug is defined
Debug is defined as true


CFLAGS=-D DEBUG=0
hello world
1 + 9 = 10
Debug is defined

2. ifeq的使用

用来作条件编译

3. 链接参数

-L.:指定库搜索路径
-l(小写L) :指定链接库名称
-I:指定头文件搜索路径

4. 特殊规则

$@:目标文件

$^:所有依赖

$<:第一个依赖

 

三、 编译:

通过make命令进行编译

编译前目录:
.
.
|-- Makefile
|-- lib
|   |-- include
|   |   `-- math_method.h
|   `-- src
|       `-- math_method.c
`-- main.c


编译后目录:
.
|-- Makefile
|-- a.out
|-- lib
|   |-- include
|   |   `-- math_method.h
|   `-- src
|       `-- math_method.c
|-- libmath_method.a
|-- libmath_method.so
|-- main.c
`-- math_method.o

 

四、源码:

LIB_A_SUPPORT=y
LIB_SO_SUPPORT=y

CC=gcc

ifeq ($(LIB_A_SUPPORT), y)
LIBRARY=-L. -Wl,-dn -lmath_method -Wl,-dy -lgcc_s
endif


ifeq ($(LIB_SO_SUPPORT), y)
LIBRARY=-L. -Wl,-dy -lmath_method -Wl,-dy -lgcc_s
endif

INCLUDE=-I./lib/include

CFLAGS=

TARGET=a.out

ifeq ($(LIB_SO_SUPPORT), y)

DEPEND_TARGET += libmath_method.so

endif

ifeq ($(LIB_A_SUPPORT), y)

DEPEND_TARGET += libmath_method.a

endif

LIB_SRCS=$(wildcard ./lib/src/*.c)
LIB_NDIR_SRCS=$(notdir $(LIB_SRCS))
LIB_OBJ=$(patsubst %.c, %.o, $(LIB_NDIR_SRCS))

$(TARGET): $(DEPEND_TARGET)
        gcc -o $@ main.c $(LIBRARY) $(INCLUDE) $(CFLAGS)

$(LIB_OBJ): $(LIB_SRCS)
        echo $(LIB_SRCS)  "f"$(LIB_OBJ)
        $(CC) -fPIC -c $(LIB_SRCS)

ifeq ($(LIB_A_SUPPORT), y)
libmath_method.a: $(LIB_OBJ)
        ar cr $@ $^
        ranlib $@

endif

ifeq ($(LIB_SO_SUPPORT), y)
libmath_method.so: $(LIB_OBJ)
        $(CC) -shared -o $@ $^

endif

.PHONY:
clean:
        -rm -rf *.o *.a *.so
        -rm $(TARGET)


main.c:
#include <stdio.h>

#include "math_method.h"

int main(int arc, char *argv[])
{
    printf("hello world\n");

    printf("%d + %d = %d\n", 1, 9, math_add(1, 9));

#ifdef DEBUG

    printf("Debug is defined\n");

#endif

#if DEBUG

    printf("Debug is defined as true\n");

#endif

    return 0;
}

math_method.c:
#include <stdio.h>


int math_add(int a, int b)
{
    return a + b;
}

int math_sub(int a, int b)
{
    return a - b;
}

math_method.h:
#ifndef __MATH_METHOD_H__
#define __MATH_METHOD_H__


int math_add(int a, int b);

int math_sub(int a, int b);

#endif

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
详细易懂的Linux makefile教程 一、概述 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。 因为,makefile关系到了整个工程的编译规则。一个工程的源文件不计数,其按类型、功能、模块分别放在若干个目录makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其也可以执行操作系统的命令。 makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。 现在讲述如何写makefile的文章比较少,这是我想写这篇文章的原因。当然,不同产商的make各不相同,也有不同的语法,但其本质都是在“文件依赖性”上做文章,这里,我仅对GNU的make进行讲述,我的环境是RedHat Linux 8.0,make的版本是3.80。必竟,这个make是应用最为广泛的,也是用得最多的。而且其还是最遵循于IEEE 1003.2-1992 标准的(POSIX.2)。 在这篇文档,将以C/C++的源码作为我们基础,所以必然涉及一些关于C/C++的编译的知识,相关于这方面的内容,还请各位查看相关的编译器的文档。这里所默认的编译器是UNIX下的GCC和CC。 二、关于程序的编译和链接 —————————— 在此,我想多说关于程序编译的一些规范和方法,一般来说,无论是C、C++、还是pas,首先要把源文件编译成间代码文件,在Windows下也就是 .obj 文件,UNIX下是 .o 文件,即 Object File,这个动作叫做编译(compile)。然后再把大量的Object File合成执行文件,这个动作叫作链接(link)。 ...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浪游东戴河

你就是这个世界的唯一

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值