typedef函数指针,在定义ClassName之前接受参数ClassName*
typedef function pointer that takes argument ClassName* before defining ClassName?
我有以下情况:
typedef void (*F_POINTER)(ClassName*);
class ClassName {
public:
F_POINTER f;
}
发生这种情况是因为ClassName的实例需要将指针本身传递给客户端。然而,如果我按这个顺序写东西,我会收到关于ClassName未声明之类的抱怨。但是,如果我切换它们,我会收到关于在类中声明实例时没有声明F_POINTER的抱怨。
所以,也许我在这里错过了一些简单的东西,但我该如何实现呢?
正向声明:
class ClassName;
typedef (*F_POINTER)(ClassName*);
class ClassName {
public:
F_POINTER f;
}
或更短:
typedef (*F_POINTER)(class ClassName*); // implicit declaration;
这似乎在GCC 4.5.2(mingw32(下工作:
typedef void (*F_POINTER)(class ClassName);
class ClassName {};
void f (ClassName) {}
int main ()
{
F_POINTER x = f;
}
我不会相信我的生命是不是合法的C++,甚至不会相信其他人描述的指针版本。前向声明和指针并不能解决所有问题,例如,不可能声明抛出不完整类型指针的方法,您需要对此进行完整定义。这可能同样是非法的,只是被编译器所接受。
正向声明ClassName
。该类型可能不完整,无法使用指向它的指针。
class ClassName;
typedef (*F_POINTER)(ClassName*);
class ClassName { ... };
或者,在类内移动typedef
。还可以考虑使用boost::function
/std::function
而不是函数指针。
您可以将其转发声明为,
class ClassName;
typedef void (*F_POINTER)(ClassName*); // assume that return is `void`
在F_POINTER
之前,或者你可以使用template
技巧来避免每个class
:的麻烦
template<typename RETURN, typename ARGUMENT>
struct FuncPtr { typedef RETURN (*F_POINTER)(ARGUMENT); };
用法:
class ClassName {
public:
FuncPtr<void,ClassName*>::F_POINTER f;
};
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- Arduino:'void (ClassName::)()' 类型的参数在附加中断时与'void (*)()'不匹配
- 需要了解参数何时在 c++ 中作为 (className&arg) 传递
- C++ 错误:宏"[ClassName]"需要 X 个参数,但只有 1 个给定
- typedef函数指针,在定义ClassName之前接受参数ClassName*