首页 > 解决方案 > 如何获得指向受概念限制的函数的函数指针?

问题描述

我有一个函数模板和一个概念的重载:

template<typename T> void f() {std::cout<< "general" << std::endl;}
template<std::integral T> void f() {std::cout<< "integral" << std::endl;}

现在我想获得一个指向该概念的函数的函数指针。当我使用辅助结构时它工作正常:

typedef void (*tF)();

template<typename T> struct H
{
   static void g() {f<T>();}
};

tF fHd = &H<double>::g;
tF fHi = &H<int>::g;

当我在没有辅助结构的情况下直接执行时,例如

tF fd = &f<double>;
tF fi = &f<int>;

GCC 10 给出错误消息:

error: converting overloaded function ‘f’ to type ‘tF’ {aka ‘void (*)()’} is ambiguous

tF fi = &f<int>;
note: candidates are: ‘void f() [with T = int]’
  template<typename T> void f() {std::cout<< "general" << std::endl;}
note:                 ‘void f() [with T = int]’
   template<std::integral T> void f() {std::cout<< "integral" << std::endl;}

这是 GCC 中的错误还是标准要求的?

标签: c++c++20c++-concepts

解决方案


现在看起来这可能是一个错误,要绕过它,您可以执行类似...

#include <type_traits>
#include <iostream>

template<typename T> void f() requires (!std::integral<T>) {std::cout<< "general" << std::endl;}
template<std::integral T> void f() {std::cout<< "integral" << std::endl;}

typedef void (*tF)();

int main() {
    tF fd = &f<double>;
    tF fi = &f<int>;
}

甚至

template<typename T> concept nonIntegral = !std::integral<T>;

template<nonIntegral T> void f() {std::cout<< "general" << std::endl;}
template<std::integral T> void f() {std::cout<< "integral" << std::endl;}

这应该可以正常工作。


推荐阅读