首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

是否可以获得要在宏中使用的方法调用的推断返回类型?

是的,可以通过使用auto关键字和decltype关键字来推断宏中方法调用的返回类型。

在宏中使用auto关键字可以让编译器根据方法调用的返回值自动推断出返回类型。例如:

代码语言:txt
复制
#define GET_RETURN_TYPE(func) decltype(func)

int add(int a, int b) {
    return a + b;
}

int main() {
    auto result = add(1, 2);
    GET_RETURN_TYPE(add) sum = add(3, 4);
    return 0;
}

在上面的例子中,GET_RETURN_TYPE宏使用了decltype关键字来推断add方法的返回类型,并将其赋值给sum变量。这样就可以在宏中获取到方法调用的推断返回类型。

需要注意的是,宏中使用auto关键字和decltype关键字只能推断出静态类型,无法获取到动态类型。另外,宏中使用auto关键字和decltype关键字推断返回类型时,需要保证方法调用是可见的,即方法的定义在宏的作用域内。

推荐的腾讯云相关产品:无

参考链接:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 泛型和元编程的模型:Java, Go, Rust, Swift, D等

    在程序设计的时候,我们通常希望使用同样的数据结构或算法,就可以处理许多不同类型的元素,比如通用的List或只需要实现compare函数的排序算法。对于这个问题,不同的编程语言已经提出了各种各样的解决方案:从只是提供对特定目标有用的通用函数(如C,Go),到功能强大的图灵完备的通用系统(如Rust,C++)。在本文中,我将带你领略不同语言中的泛型系统以及它们是如何实现的。我将从C这样的不具备泛型系统的语言如何解决这个问题开始,然后分别展示其他语言如何在不同的方向上逐渐添加扩展,从而发展出各具特色的泛型系统。 泛型是元编程领域内通用问题的简单案例:编写可以生成其他程序的程序。我将描述三种不同的完全通用的元编程方法,看看它们是如何在泛型系统空的不同方向进行扩展:像Python这样的动态语言,像Template Haskell这样的过程宏系统,以及像Zig和Terra这样的阶段性编译。

    03

    《带你装B,带你飞》pytest成魔之路4 - fixture 之大解剖

    fixture是pytest的一个闪光点,pytest要精通怎么能不学习fixture呢?跟着我一起深入学习fixture吧。其实unittest和nose都支持fixture,但是pytest做得更炫。 fixture是pytest特有的功能,它用pytest.fixture标识,定义在函数前面。在你编写测试函数的时候,你可以将此函数名称做为传入参数,pytest将会以依赖注入方式,将该函数的返回值作为测试函数的传入参数。 fixture有明确的名字,在其他函数,模块,类或整个工程调用它时会被激活。 fixture是基于模块来执行的,每个fixture的名字就可以触发一个fixture的函数,它自身也可以调用其他的fixture。 我们可以把fixture看做是资源,在你的测试用例执行之前需要去配置这些资源,执行完后需要去释放资源。比如module类型的fixture,适合于那些许多测试用例都只需要执行一次的操作。 fixture还提供了参数化功能,根据配置和不同组件来选择不同的参数。 fixture主要的目的是为了提供一种可靠和可重复性的手段去运行那些最基本的测试内容。比如在测试网站的功能时,每个测试用例都要登录和退出,利用fixture就可以只做一次,否则每个测试用例都要做这两步也是冗余。

    03

    【java筑基】浅谈代码复用技术——继承、组合

    一、继承 1.1 继承的特点 子类可以获得父类的全部成员变量和方法称为继承,注意子类不能够继承父类的构造器。Java具有单继承的特点,一个类只能够有一个直接父类。所有类都继承了java.lang.Object类。 1.2 重写 子类可以对父类方法进行重写,重写必须遵守两小两同一大,即子类方法返回值的类型要比父类方法返回值类型要更小或者相同(儿子排场要小),子类方法的异常类型要比父类方法的异常类型要更小或者相同(儿子犯的错误要更少),方法名要相同,形参列表要相同,访问权限要比父类访问权限更大或者相同(儿子要搞出点名堂,让别人看见)。特别注意的是子类与父类重写的方法不能一个是属于类,一个是属于对象的。

    01

    JDK1.7新特性

    1 对集合类的语言支持;  2 自动资源管理;  3 改进的通用实例创建类型推断;  4 数字字面量下划线支持;  5 switch中使用string;  6 二进制字面量;  7 简化可变参数方法调用。     下面我们来仔细看一下这7大新功能:  1 对集合类的语言支持        Java将包含对创建集合类的第一类语言支持。这意味着集合类的创建可以像Ruby和Perl那样了。        原本需要这样:           List<String> list = new ArrayList<String>();           list.add("item");           String item = list.get(0);           Set<String> set = new HashSet<String>();           set.add("item");           Map<String, Integer> map = new HashMap<String, Integer>();           map.put("key", 1);           int value = map.get("key");        现在你可以这样:           List<String> list = ["item"];           String item = list[0];           Set<String> set = {"item"};           Map<String, Integer> map = {"key" : 1};           int value = map["key"];        这些集合是不可变的。  2 自动资源管理        Java中某些资源是需要手动关闭的,如InputStream,Writes,Sockets,Sql classes等。这个新的语言特性允许try语句本身申请更多的资源,     这些资源作用于try代码块,并自动关闭。        这个:           BufferedReader br = new BufferedReader(new FileReader(path));           try {           return br.readLine();                 } finally {                     br.close();           }        变成了这个:            try (BufferedReader br = new BufferedReader(new FileReader(path)) {               return br.readLine();            }        你可以定义关闭多个资源:           try (               InputStream in = new FileInputStream(src);               OutputStream out = new FileOutputStream(dest))           {           // code           }        为了支持这个行为,所有可关闭的类将被修改为可以实现一个Closable(可关闭的)接口。  3 增强的对通用实例创建(diamond)的类型推断        类型推断是一个特殊的烦恼,下面的代码:           Map<String, List<String>> anagrams = new HashMap<String, List<String>>();        通过类型推断后变成:           Map<String, List<String>> anagrams = new HashMap<>();        这个<>被叫做diamond(钻石)运算符,这个运算符从引用的声明中推断类型。        很长的数字可读性不好,在Java 7中可以使用下划线分隔长int以及long了,如:           int one_million = 1_000_000;     运算时先去除下划线,如:1_1 * 10 = 110,120 – 1_0 = 110    5 switch中使用string       以前你在switch中只能使用number或enum。现在你可以使用string了:           String s = ...           switch(s) {

    02
    领券