Makefile 是如何工作的?其中的宏定义分别是啥意思?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile 是如何工作的?其中的宏定义分别是啥意思?相关的知识,希望对你有一定的参考价值。
你问的问题就好比一个国家是如何运作的。其中各个部委都是干什么的。因此有点难以回答。不过可以从以下几点进行简单解释:makefile是一个文本文件,用于描述程序源代码之间以及程序可执行代码与源代码之间的依赖关系。
简单例子:最终编译生成的可执行文件ab.out是由a.c和b.c共同编译生成的,那么make文件就要写两行:
ab.out: a.c b.c
gcc a.c b.c -o ab.out
第一行描述了依赖关系,第二行描述了依赖关系是如何达成的。
更复杂的例子:最终编译生成的可执行文件ab.out是由a.c和b.obj功能编译生成的,而b.obj是由b1.c和b2.c编译而成,那么要写好多行:
ab.out: a.c b.obj
gcc a.c b.obj -o ab.out
b.obj: b1.c b2.c
gcc -c b1.c b2.c -o b.obj
这就是makefile的工作方法。
关于宏定义,简单点说就是文本替换。为了方便使用不同的编译器或者编译环境以及硬件环境,一些复杂的软件使用了大量的宏定义来代替诸如“gcc”这样的最基本的东西。不要太在意红定义,多看,从简单的看起,就会了。 参考技术A 不同的make除了相似之处外,有很多不同的细节,你这样问,我只能说,一般从一个总的目标开始,根据依赖关系进行处理。网上有教程,自己看看。 参考技术B 。#用来把参数转换成字符串,##则用来连接两个前后两个参数,把它们变成一个字符串。
#include <stdio.h>
#define paster( n ) printf( "token " #n" = %d\n ", token##n )
int main()
int token9=10;
paster(9);
return 0;
输出为
[leshy@leshy src]$ ./a.out
token 9 = 10
另外,团IDC网上有许多产品团购,便宜有口碑
C语言中的宏定义如何使用?
C语言中的宏定义如何使用?学一维数组时老师说 #define N a int a[N]是正确的,但是我上机试的时候有点问题,不知道是数组出了问题还是咋了,希望哪位大佬帮忙看下。谢谢。
宏定义又称为宏代换、宏替换,简称"宏"。格式:
#define 标识符 字符串
其中的标识符就是所谓的符号常量,也称为"宏名"。
预处理(预编译)工作也叫做宏展开:将宏名替换为字符串。
掌握"宏"概念的关键是"换"。一切以换为前提、做任何事情之前先要换,准确理解之前就要"换"。
即在对相关命令或语句的含义和功能作具体分析之前就要换:
例:
#define Pi 3.1415926
把程序中出现的Pi全部换成3.1415926 参考技术A 您好!很高兴为您解答。
宏定义的用处主要体现在便于程序的调试上。
比如我要写一个计算圆相关信息(周长、面积等等)的程序,需要定义π(3.14):
#define PI 3.14
那么势必PI这个标识可以在程序中代替所有的3.14,如果我发现计算的精度不够,需要π的更多有效位时,则只需将宏定义修改为:
#define PI 3.1415926
那么程序中的所有PI都会变成3.1415926
可想而知,没有宏定义,我需要将代码中全部的3.14都手动改为3.1415926
即使是定义double PI=3.14;,你会发现当代码很长时,在乱军丛中找到一行“double PI=3.14;”是多么困难的事。
又比如数组,定义时是不能出现“int a[n];”这样的定义的,编译通不过,因为必须规定数组长度。
但如果是:
#define N 10
int a[N];
就可以,对宏定义编译器是不作检查的,应为宏定义只是简单的符号替换。所以一旦我还没有确定要定义多长的数组,但又想通过编译时,就可以提现宏定义的用处了。
如此看来,宏定义提升了程序编写的灵活性。
望采纳~如您还有不解,欢迎追问~ 参考技术B 正确的完整输出 3 个整数的程序结构应该按照如下写法:
#define N 3
#include <stdio.h>
int main( )
int i, a[N] = 1, 2, 3 ;
for(i = 0 ; i < N ; i ++ ) /* 循环输出整数数组 a 中的 3 个数字,特别要注意:i 必须要写成:i < N,而不能够写成:i <= N,否则的话,就会产生越界错误。 */
printf("%d\t", a[i] ) ;
printf("\n" );
return 0 ;
由于 C 语言的数组下标是从 0 开始的,而不是像 PASCAL 语言那样是从 1 开始的。故
你原来的程序语句中:
#define N 3
printf("%d", a[N]) ; 用 N = 3 替换 a[N],就变成了:printf("%d", a[3]) ; 那就肯定越界了。追问
那那个a[3]不就是代表a[0] a[1] a[2]刚好三个数吗?为啥会越界?
追答你说的 a[3] 整数数组,确实是代表 a[0]、a[1]、a[2] 刚好三个数字,但是你在 printf(“%d”, a[N]) ; 语句中,因为你定义的是 N 的值为 3,所以将 N 的值代入上面的输出语句,
就变成了:printf(“%d”,a[3]);
还是我前面说的那个问题:在 C 语言中数组的有效下标是从 0 开始的,而不是从 1 开始的,所以在输出 a[3] 时,程序自然就会越界出错了。
噢……懂了懂了
(๑•̀ㅂ•́)و✧非常感谢
追答不客气。编写程序肯定是需要积累丰富的编程经验的。祝你编程越来越进步!
本回答被提问者和网友采纳 参考技术C 数组下标从0开始,a[N]要改成a[N-1],否则下标越界了。 参考技术D printf这一行末尾的;改一下, 不要使用中文输入法.以上是关于Makefile 是如何工作的?其中的宏定义分别是啥意思?的主要内容,如果未能解决你的问题,请参考以下文章