C++中的模板化函数指针
Templated Function Pointer in C++
我遇到了模板化成员函数指针的问题。代码如下所示。
#include <String>
#include <iostream>
template<typename T>
struct method_ptr
{
typedef void (T::*Function)(std::string&);
};
template <class T>
class EventHandler
{
private:
method_ptr<T>::Function m_PtrToCapturer;
};
e:\EventHandler.h(13):错误 C2146:语法错误:标识符"m_PtrToCapturer"之前缺少";"
我正面临此错误。
即使我使用
method_ptr<EventHandler>::Function m_PtrToCapturer;
作为成员变量,我得到与上述相同的错误。
因为method_ptr<T>::Function
是一个依赖名称(依赖于T
),所以你需要用typename
来消除歧义:
template <class T>
class EventHandler
{
private:
typename method_ptr<T>::Function m_PtrToCapturer;
// ^^^^^^^^
};
这有效,
struct method_ptr
{
typedef void (T::*Function)(std::string&);
};
template <class T>
class EventHandler
{
private:
typename method_ptr<T>::Function m_PtrToCapturer;
};
从 C++11 开始,您可以使用 using
.
template <typename T>
using Function = void (T::*)(std::string);
(顺便问一下,为什么std::string
按值调用?我推荐const std::string &
。
啊哈,我想通了你的第二个问题。
template <typename T>
method_ptr<T>::Function m_PtrToMemFunc; //<--
模板仅适用于类和函数(以及CPP11的typedef&using...)。 你应该这样写。
method_ptr<SomeClass>::Function m_PtrToMemFunc;
相关文章:
- QMetaObject invokeMethod的基于函数指针的语法
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- c++r值引用应用于函数指针
- 模板函数指针和lambda
- 是否可以将llvm::FunctionType转换为C/C++原始函数指针
- 带有类的函数指针
- () 函子后面的括号,而不是函数指针?
- 全局作用域中函数指针的赋值
- 使用"Task"函数指针队列定义作业管理器
- 将成员函数指针作为参数传递给模板方法
- 如何创建对象函数指针C++映射?
- 匹配函数指针作为模板参数?
- 通过函数指针定义类范围之外的方法
- 存储在类中的函数指针
- C++从函数指针数组调用函数
- 将返回值存储在函数指针数组的指针中是如何工作的?
- 整数键映射到头文件中的成员函数指针
- 从类成员函数到类 C 函数指针的转换
- 如何将内联匿名函数分配给C++函数指针
- 将字符缓冲区强制转换为函数指针