linux c # ## __VA_ARGS__ 使用

本文介绍了C++预处理器宏中的特殊符号#、##和__VA_ARGS__的用途。#用于将参数转换为字符串,##用于连接两个标识符,__VA_ARGS__用于处理可变参数列表。示例展示了它们在宏定义和函数调用中的应用。

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

目录

 # 用来把参数转换成字符串

## 用于将带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串;但它不可以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元

__VA_ARGS__ 用于在宏替换部分中,表示可变参数列表

##__VA_ARGS__  宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错


使用打印信息的接口时,经常见到__VA_ARGS__和##__VA_ARGS__这两个字符串,花时间学习下这部分的知识,发现还有#和##这两个比较有意思的字符串,记下他们的用法:

 # 用来把参数转换成字符串

例:

#include <iostream>
 
#define LOG(x) do { printf("%s=%d\n",#x,x); }while(0)
 
int main()
{
    int score = 96;
    LOG(score);
    LOG(6);
    
    getchar();
    return 0;
}

输出:

## 用于将带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串;但它不可以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元

例:

#include <iostream>
 
#define LOG(x) log##x()
 
void logA(){
    printf("log func A \n");
}
 
void logB(){
    printf("log func B\n");
}
 
int main()
{
    LOG(A);
 
    getchar();
    return 0;
}

输出:

__VA_ARGS__ 用于在宏替换部分中,表示可变参数列表

例:

#include <iostream>
 
#define LOG(...)  printf(__VA_ARGS__);
 
int main()
{
    LOG("score is %d\n",96);
 
    getchar();
    return 0;
}

输出:

##__VA_ARGS__  宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错

### Linux 中 `PRT_DBG` 宏定义及其使用场景 在嵌入式开发和内核调试过程中,宏定义用于简化代码编写并提高可维护性和灵活性。对于 `PRT_DBG` 这样的宏,在Linux环境中通常被用来实现不同级别的日志记录功能。 #### 宏定义解析 考虑一个典型的 `PRT_DBG` 实现方式: ```c #define PRT_DBG(fmt, ...) printk(KERN_DEBUG "[DEBUG] " fmt "\n", ##__VA_ARGS__) ``` 此宏利用了C预处理器特性来处理变参列表[^2]。具体来说,当调用带有参数的 `PRT_DBG` 时,这些参数会被传递给内部使用的 `printk()` 函数;如果没有额外参数,则通过 `##` 操作符移除多余的逗号,从而避免编译错误。 #### 使用实例 下面展示了一个具体的例子,说明如何应用该宏来进行调试信息输出: ```c #include <linux/kernel.h> #include <linux/module.h> static int __init my_module_init(void) { int value = 42; // 调试信息打印 PRT_DBG("The current value is %d.", value); return 0; } module_init(my_module_init); MODULE_LICENSE("GPL"); ``` 在这个案例中,每当模块初始化成功后会执行一次调试信息打印操作,显示当前变量 `value` 的数值。由于采用了 `KERN_DEBUG` 前缀,这使得消息能够在适当的日志级别下呈现出来。 #### 日志等级控制 值得注意的是,实际项目里可能会存在多种不同的日志等级(如警告、错误等),因此可以通过设置全局或局部变量的方式动态调整哪些类型的日志应该被捕获并显示。例如,如果只希望看到警告及以上级别的信息,则可以相应地配置环境变量或其他形式的开关机制[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值