Linux __stringify && __stringify_1

本文探讨了Linux中Stringify宏的实现原理,解释了为何需要两层间接转换以支持参数为宏的情况,并通过示例对比了不同实现方式的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux中有个stringify的头文件,里面主要的内容如下:

#ifndef __LINUX_STRINGIFY_H
#define __LINUX_STRINGIFY_H

/* Indirect stringification.  Doing two levels allows the parameter to be a
 * macro itself.  For example, compile with -DFOO=bar, __stringify(FOO)
 * converts to "bar".
 */

#define __stringify_1(x...)	#x
#define __stringify(x...)	__stringify_1(x)

#endif	/* !__LINUX_STRINGIFY_H */

里面有两个define,依照注释看的不太明白。为什么中间要通过__stringify_1转换一下呢?直接使用#define __stringify(x...) #x岂不是更加简洁?


编程测试一下:

#include <stdio.h>

#define AAA BBB

#define __stringify_1(x...) #x
#define __stringify(x...) __stringify_1(x)

#define __stringify_src(x...) #x

main()
{
	printf("stringify(AAA):     %s\n", __stringify(AAA));
	printf("stringify_src(AAA): %s\n",__stringify_src(AAA));
}

运行的结果如下:

stringify(AAA):     BBB
stringify_src(AAA): AAA

然后回过头来看注释,就一清二楚了。

不过注释里有这一句“Doing two levels allows the parameter to be a macro itself.”

该怎么理解呢?

如果在#define AAA BBB之前再定义一个#define BBB CCC,#define CCC DDD ......,这个程序运行的结果如何呢?

呵呵,大家可以尝试一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值