实现只有C++98特性的std::result_of可以通过以下步骤:
template <typename Func, typename Arg>
struct result_of {
typedef typename Func::template result<Arg>::type result;
};
在上述代码中,我们使用模板参数Func表示函数类型,使用模板参数Arg表示函数参数类型。通过调用Func的result模板成员,我们可以获取函数调用的返回类型。
template <typename T>
struct function_object {
template <typename Arg>
struct result {
typedef typename T::template result<Arg>::type type;
};
};
在上述代码中,我们使用模板参数T表示函数类型。通过调用T的result模板成员,我们可以获取函数调用的返回类型。
template <typename Func, typename Arg>
struct result_of {
typedef typename Func::template result<Arg>::type result;
};
template <typename T>
struct function_object {
template <typename Arg>
struct result {
typedef typename T::template result<Arg>::type type;
};
};
// 示例用法
struct MyFunc {
template <typename Arg>
struct result {
typedef int type;
};
};
typedef result_of<function_object<MyFunc>, int>::result ResultType;
在上述示例中,我们定义了一个函数类型MyFunc,该函数类型返回类型为int。通过使用result_of类和function_object类,我们可以获取函数调用的返回类型,并将其定义为ResultType。
这样,我们就实现了只有C++98特性的std::result_of。请注意,这只是一个简单的示例,实际使用中可能需要根据具体情况进行调整和扩展。
腾讯云相关产品和产品介绍链接地址:
领取专属 10元无门槛券
手把手带您无忧上云