C++-cout中重载操作符<<输出函数指针

发布于 2016-11-22 09:57:08 字数 438 浏览 1331 评论 1

#include "stdafx.h"

class A;
typedef void (A::*FUNC)(void);

using namespace std;
class A
{
public:
void fun(void);
};
void A::fun(void)
{
cout<<123<<endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
FUNC pf = NULL;
pf = A::fun;
cout<<pf<<endl;
scanf("%s");
return 0;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

偏爱自由 2017-10-04 17:53:21

指向类成员函数的“指针”不是指针,而是一个很复杂的结构,其具体的实现依赖于编译器的实现,由于cout没有重载这类“指针”,只重载了void, 因此要利用cout来输出这类“这类指针”,有一种方法是
cout << (void
&)pf << endl;
这可能与平台相关,不一定每个平台都能成功。另外还可以利用printf输出该地址:
printf("%pn", pf);

解释:该指向类成员函数的指针有一个结构与之相对应,不是一个简单的地址,例如该结构中有一个flag指示成员函数是否为虚函数,如果是虚函数,那么结构中就应该有个元素保存了虚表的地址,用以调用虚表中的函数;如果不是虚函数,那么结构中就应该有一个元素保存该函数的实际地址。如果想进一步了解可见How to print member function address in C++ 以及Member Function Pointers and the Fastest Possible C++ Delegates中的Member Function Pointers - why are they so complex?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文