C++ 获取函数名和变量名

本文探讨了C++20引入的source_location特性,如何通过它获取函数名、文件名、行号和列数,以及在实际代码中的应用实例,展示了新功能如何提升代码可读性和调试效率。

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

C++ 中可以通过宏来获取函数的名称和变量的名称,__func__ 就是函数的名称。获取变量名称可以使用以下自定义宏

#define NAME(variable) (#variable)

例子:

#include <iostream>
#define NAME(variable) (#variable)

auto mysum(int a, int b)
{
  std::cout << "function name: " << __func__ << std::endl;
  std::cout << NAME(a) << " + " << NAME(b) << " = " << (a + b) << std::endl;
  return a + b;
}

int main()
{
  auto s = mysum(5, 10);
  std::cout << typeid(s).name() << std::endl;
  return 0;
}

输出如下:

function name: mysum
a + b = 15
int

在 C++ 20 中还引入了 source_location,通过该结构体可以直接获取文件名,当前代码所在行,列和函数的名称

例子:

#include <iostream>
#include <string_view>
#include <source_location>

void log(const std::string_view message,
    const std::source_location location =
    std::source_location::current())
{
    std::cout << "file: "
        << location.file_name() << "("
        << location.line() << ":"
        << location.column() << ") `"
        << location.function_name() << "`: "
        << message << '\n';
}

template <typename T> void fun(T x)
{
    log(x);
}

int main(int, char* [])
{
    log("Hello world!");
    fun("Hello C++20!");
}

输出如下:

file: D:\VS_Projects\HelloWorld\HelloWorld\main.cpp(24:5) `main`: Hello world!
file: D:\VS_Projects\HelloWorld\HelloWorld\main.cpp(19:5) `fun`: Hello C++20!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值