如何获取指向受概念限制的函数的函数指针?
How do I get the function pointer to a function restricted by a concept?
我有一个函数模板和一个概念的重载:
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 中的错误还是标准要求
?看起来这可能是一个错误,要解决它,您可以做一些类似的事情......
#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;}
这应该可以正常工作。
相关文章:
- QMetaObject invokeMethod的基于函数指针的语法
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- c++r值引用应用于函数指针
- 模板函数指针和lambda
- 是否可以将llvm::FunctionType转换为C/C++原始函数指针
- 带有类的函数指针
- () 函子后面的括号,而不是函数指针?
- 全局作用域中函数指针的赋值
- 使用"Task"函数指针队列定义作业管理器
- 将成员函数指针作为参数传递给模板方法
- 如何创建对象函数指针C++映射?
- 匹配函数指针作为模板参数?
- 通过函数指针定义类范围之外的方法
- 存储在类中的函数指针
- C++从函数指针数组调用函数
- 将返回值存储在函数指针数组的指针中是如何工作的?
- 整数键映射到头文件中的成员函数指针
- 从类成员函数到类 C 函数指针的转换
- 如何将内联匿名函数分配给C++函数指针
- 将字符缓冲区强制转换为函数指针