类的成员函数指针作为参数传递给其他函数和普通函数指针的传递是不同的

类的成员函数指针作为参数传递给其他函数和普通函数指针的传递是不同的,普通函数指针的传递
只要在参数声明中声明是相同参数个数、类型和相同返回类型的函数指针int (*p)(int),传递时只需传函数名就可以了.
可是传递成员函数指针用此方法却不能工作。指针是指向一些内存地址的变量,既可以是数据的地址也可以是函数的地址。C++的 成员指针遵从同样的原则。但在类内部没有地址;选择一个类的成员意味着在类中偏移。只有把这个偏移和具体对象的开始地址结合,才能得到实际地址。成员指针的语法要求选择一个对象的同时逆向引用成员指针。
先来看看一个错误的例子:
//---------------------------------------------------------------------------
class A
{
public:
        int fun1(int i){return i;};
};

void fun2(int j, int (A::*p)(int)){
        cout <<p(j);
}

void main()
{
        A oba;
        int i=1;
        fun2(i,oba.fun1);  //this is an error
}
//---------------------------------------------------------------------------


为了能够正确地传递成员函数指针,我们先来看看成员参数、成员函数指针正确的声明方法:
//---------------------------------------------------------------------------
class A
{
public:
 int i1;
        int fun1(int i){
                return i;
        };
};

void main()
{
 int (A::*fp1)(int);    //声明fp1为class A中的成员函数指针
        int A::*ip1;           //声明ip1为class A中的成员变量指针
 fp1=&A::fun1;          //初始化fp1
 ip1=&A::i1;            //初始化ip1
 A oba;
 oba.*ip1=2;
 (oba.*fp1)(oba.*ip1);
}
//---------------------------------------------------------------------------


以下为正确传递成员函数指针的例子:
//---------------------------------------------------------------------------
class A
{
public:
        int fun1(int i){
                return i;
        };
};

template <class T>
void fun2(int j, T *obp, int (T::*p)(int)){
        cout <<(obp->*p)(j);
}

void main()
{
        int (A::*fp1)(int);//声明fp1为class A中的成员函数指针
        fp1=&A::fun1;  //初始化fp1
        A oba;
 A *obap=&oba;
 int i=1;
        fun2(i,obap,fp1);
}
//---------------------------------------------------------------------------

当然,可以把成员函数声明为static(静态函数),这样传递它的指针就像传递普通函数一样。但是又涉及一个问题:类中如何在static 函数中调用 非static 函数 。
方法:使用静态成员函数
使回调成员函数为静态。因为静态成员函数不带隐含式参数“this”。因此,可以将其参数中的地址当作是普通函数的指针来使用。如果要从静态成员函数中访问对象的数据成员,显式传入对象的地址即可。例如:
//---------------------------------------------------------------------------
class Hack
{
private:
 int x;
public:
 int get_x();// 非静态成员函数
 static void func(Hack * pthis); // 静态成员函数
 void func2(); // 非静态成员函数
};

void Hack::func(Hack * pthis)
{
 int y = pthis->get_x(); // 访问对象的数据成员
}
//---------------------------------------------------------------------------

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++中,可以将成员函数函数名作为参数传递给另一个函数。具体实现方式是使用函数指针和`std::function`。 如果你想传递一个普通成员函数函数指针,你需要将其绑定到一个对象上,例如: ```cpp class A { public: int foo(int x) { return x + 1; } }; class B { public: void bar(int (A::*p)(int), A* obj) { int res = (obj->*p)(10); std::cout << res << std::endl; } }; int main() { A a; B b; b.bar(&A::foo, &a); // pass the function pointer and object pointer return 0; } ``` 在上面的例子中,`A`有一个名为`foo`的成员函数,`B`有一个名为`bar`的函数,`bar`函数参数型为成员函数指针和对象指针,可以接受一个以整数为参数、返回整数的成员函数。 在`main`函数中,我们创建了一个`A`的对象和一个`B`的对象,然后将`foo`函数函数指针和`a`对象的指针作为参数传递给了`bar`函数,这样`bar`函数就可以调用`foo`函数了。 如果你想使用`std::function`传递成员函数,你需要使用`std::bind`来将成员函数和对象绑定成一个可调用对象,例如: ```cpp #include <functional> class A { public: int foo(int x) { return x + 1; } }; class B { public: void bar(std::function<int(int)> f) { int res = f(10); std::cout << res << std::endl; } }; int main() { A a; B b; auto f = std::bind(&A::foo, &a, std::placeholders::_1); b.bar(f); return 0; } ``` 在上面的例子中,我们使用`std::bind`将`foo`函数和`a`对象绑定成一个可调用对象`f`,然后将`f`作为参数传递给了`bar`函数,这样`bar`函数就可以调用`foo`函数了。注意,`std::placeholders::_1`表示占位符,将在调用`f`函数时传入。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值