如何从指针到方法获取类(对象类型)

How get the class (object type) from pointer to method

本文关键字:对象 类型 获取 方法 指针      更新时间:2023-10-16

我有一个指向该方法的指针:

struct A { int method() { return 0; } };
auto fn = &A::method;

我可以通过 std::result_of 获取返回类型,但是我如何从 fn 获取该方法的类所有者?

您可以使用类模板专用化来匹配它:

//Primary template
template<typename T> struct ClassOf {};
//Thanks T.C for suggesting leaving out the funtion /^argument
template<typename Return, typename Class>
struct ClassOf<Return (Class::*)>{   using type = Class;    };
//An alias
template< typename T> using ClassOf_t = typename ClassOf<T>::type;

因此给出:

struct A { int method() { return 0; } };
auto fn = &A::method;

我们可以像这样检索类:

ClassOf_t<decltype(fn)> a;

完整示例 这里.

试试这个:

template<class T>
struct MethodInfo;
template<class C, class R, class... A>
struct MethodInfo<R(C::*)(A...)> //method pointer
{
    typedef C ClassType;
    typedef R ReturnType;
    typedef std::tuple<A...> ArgsTuple;
};
template<class C, class R, class... A>
struct MethodInfo<R(C::*)(A...) const> : MethodInfo<R(C::*)(A...)> {}; //const method pointer
template<class C, class R, class... A>
struct MethodInfo<R(C::*)(A...) volatile> : MethodInfo<R(C::*)(A...)> {}; //volatile method pointer

提升可调用特征答案,我更喜欢这里比较短的答案,因为它对我来说更具可读性,但意见可能会有所不同......

#include<string>
#include<type_traits>
#include<tuple>
#include <boost/callable_traits/args.hpp>
struct S{
    int val=46;
    int get(){
        return val;
    }
    void method(const std::string ){
    }
};
int main(){
    using Ts1 = boost::callable_traits::args_t<decltype(&S::val)>;
    using Ts2 = boost::callable_traits::args_t<decltype(&S::get)>;
    using Ts3 = boost::callable_traits::args_t<decltype(&S::method)>;
    std::remove_cvref_t<std::tuple_element<0,Ts1>::type> s1;
    s1.val++;
    std::remove_cvref_t<std::tuple_element<0,Ts2>::type> s2;
    s2.val++;
    std::remove_cvref_t<std::tuple_element<0,Ts3>::type> s3;
    s3.val++;
}

s1s2s3都是S型。

显然,您只需要执行一次逻辑,我做了 3 次以表明它适用于指向成员的指针、指向需要 0 个参数的函数的指针、指向需要 1 个参数的函数的指针。