类的operator隐式类型转换为函数指针以及类的伪函数operator()同时存在时二者的选择问题

本人萌新一枚,有任何问题希望大神们可以指出,这段时间详细的看了一下c++11的新标准。偶然的机会想到了这个问题,如果在同一类中将类的隐私类型转换为function<void(*)(void)>,即返回一个格式为static void function(void)形式的函数,然后定义一下伪函数,即将运算符()重载为同样形式的函数(即void function(void)类型)。显然,上述二者存在任一一个,该类的类对象都可以直接视为可以调用的函数对象,问题就来了,如果二者同时存在,会优先调用谁呢? 之前阅读祁宇老师的深入应用c++11时没有提及,也没有看过相关的资料,于是乎就简单写了写来验证,代码如下。

#include<iostream>
#include<functional>
using namespace std;
class A    //类A作为承载可调用函数的一个容器,基于function容器实现,功能只有两个:构造和调用函数然后执行。
{
private:
	function<void(void)> f;
public:
	A(const function<void(void)>& func) :f(func){};
	void run();
};
void A::run()
{
	f();
}
class B
{
	using type_ = void(*)(void);//函数指针别名,c++新用法,相当于typedef void(*type_)(void)。
private:
	static void fun(){ cout << "hiden" << endl; };
public:     
	void operator()(void){ cout << "hello" << endl; };  //重载()符号。类对象可以看作伪函数。
	operator type_(){ return fun; };//operator隐私类型转换,将类对象转换为函数类型。
};
int main()
{
        B b;
	A a(b);
	a.run();
        system("pause");
        return 0;
}   
      执行后发现结果是打印了hello,说明A类在构造优先使用了重载运算符(),将对象b视为伪函数,并没有优先使用隐式类型转换将。如果将void operator()(void){cout<<"hello"<<endl;};去掉,打印结果式hiden,A类在构造时将b隐式转换,返回了静态函数static void fun()。所以当二者同时存在时,operator()伪函数的优先级高于operator隐式类型转换。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值