C语言进阶第21式:宏定义与使用分析

C语言进阶第21式:宏定义与使用分析,第1张

问题1:C语言中如何使用宏定义?

C语言中的宏定义

1、#define是预处理器处理的实体单元之一;

2、#define定义的宏可以出现在程序的任意位置;

3、#define定义之后的代码都可以使用这个宏;

 

定义宏常量

1、#define定义的宏常量可以直接使用;

2、#define定义的宏常量本质为字面量;

例子:宏定义分析


#define ERROR -1
#define PATH1 "D:\test\test.c"
#define PATH2 D:\test\test.c
#define PATH3 D:\test\
test.c

int main()
{
    int err = ERROR;
    char* p1 = PATH1;
    char* p2 = PATH2;
    char* p3 = PATH3;
}

宏定义表达式

1、#define表达式的使用类似函数调用

2、#define表达式可以比函数更强大

3、#define表达式比函数更容易出错

例子:宏定义表达式分析

// #include 

#define _SUM_(a, b) (a) + (b)
#define _MIN_(a, b) ((a) < (b) ? (a) : (b))
#define _DIM_(a) sizeof(a)/sizeof(*a)


int main()
{
    int a = 1;
    int b = 2;
    int c[4] = {0};

    int s1 = _SUM_(a, b);
    int s2 = _SUM_(a, b) * _SUM_(a, b);
    int m = _MIN_(a++, b);
    int d = _DIM_(c);

    // printf("s1 = %d\n", s1);
    // printf("s2 = %d\n", s2);
    // printf("m = %d\n", m);
    // printf("d = %d\n", d);

    return 0;
}

宏表达式与函数的对比

1、宏表达式被预处理器处理,编译器不知道宏表达式的存在;

2、宏表达式用“实参”完全替代形参,不进行任何运算;

3、宏表达式没有任何的“调用”开销;

4、宏表达式中不能出现递归调用;

有趣的问题。



宏定义的常量或表达式是否有作用域限制?

例子:宏的作用域分析

// #include 

void def()
{
    #define PI 3.1415926
    #define AREA(r) r * r * PI
}

double area(double r)
{
    return AREA(r);
}

int main()
{
    double r = area(5);

    // printf("PI = %f\n", PI);
    // printf("d = 5; a = %f\n", r);
    
    return 0;
}

强大的内置宏

含义实例
_FILE_被编译的文件名file1.c
_LINE_当前行号25
_DATA_编译时的日期Jan 31 2012
_TIME_编译时的时间17:01:01
_STDC_编译器是否遵循标准C规范1

#include 
#include 

#define MALLOC(type, x) (type*)malloc(sizeof(type)*x)

#define FREE(p) (free(p), p=NULL)

#define LOG(s) printf("[%s] {%s:%d} %s \n", __DATE__, __FILE__, __LINE__, s)

#define FOREACH(i, m) for(i=0; i

小结

1、预处理器直接对宏进行文本替换;

2、宏使用时的参数不会进行求职和运算;

3、预处理器不会对宏定义进行语法检查;

4、宏定义时出现的语法错误只能被编译器检测;

5、宏定义的效率高于函数调用;

6、宏的使用会带来一定的副作用;

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/675120.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-04-19
下一篇2022-04-19

发表评论

登录后才能评论

评论列表(0条)