C++中使用函数地址强制调用私有成员函数

最近写c++遇到一个小问题,就是调用brpc库里面的discovey中的拉取server节点函数时,发现这个函数是私有的,直接调用肯定不行。官方给的使用方法是通过初始化channnel,之后的拉取server节点的工作都交给brpc来做。但是想拿到拉取后的节点,就不好做了。
拉取函数Getservers
C++中使用函数地址强制调用私有成员函数_第1张图片
无奈之举,想出两种方案:
1.强制调用brpc里面的私有函数Getservers;
2.按照brpc的方法自己实现Getservers函数的功能;

这里出于安全等一系列原因考虑,就只能采取第二种方案。但是今天试了下,强制调用也是ok的。

#include 
using namespace std;
class A {
private:
    virtual void func() {
        std::cout << "A: func()" << std::endl;
    }
    int a = 1000000;
};
class B:public A {
public:
    void func() {
        std::cout << "B: func()" << std::endl;
    }
};
typedef void(*fun)();

int main(int argc, const char * argv[]) {
    // insert code here...
    //func("10.0");
    A a;
    long* ptr = reinterpret_cast<long*>(&a);    //取对象地址的前8个字节
    cout << "对象a的地址" << &a <<endl;
    cout << "对象a的地址" << ptr <<endl;
    
    long* p = reinterpret_cast<long*>(*ptr);//对ptr解引用,就是虚表的地址
    cout << "虚表地址" << p <<endl;
    cout << "第一个虚函数地址:" << p[0] << endl;

    fun point = (fun)(p[0]);
    cout << "第一个虚函数地址" << (long)point <<endl;
    point();
    return 0;
}

用xcode测试了下,的确可以调用。原理就是根据类对象模型,找到虚函数表中的虚函数。之后声明一个和私有成员函数相同的函数指针,就可以调用。
C++中使用函数地址强制调用私有成员函数_第2张图片

你可能感兴趣的:(C++)