为什么不能从C 11中的非限定成员函数名称获取指向成员的指针?

前端之家收集整理的这篇文章主要介绍了为什么不能从C 11中的非限定成员函数名称获取指向成员的指针?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下代码
struct X
{
    void f() {}

    void g()
    {
        auto h = &f;
    }
};

结果是:

error: ISO C++ forbids taking the address of an unqualified
or parenthesized non-static member function to form a pointer
to member function.  Say ‘&X::f’

我的问题是,为什么这个标准不允许和禁止这个?作为用户,将它称为不合格会更方便,所以我假设有一些其他的基本原理(安全性?模糊性?编译器实现的简易性?)?

解决方法

指向成员的指针非常罕见,可以进行特殊处理,而不一定是最经济的处理.决定唯一接受的形式是错误消息中引用的形式.在任何情况下,这种形式都不会与其他任何形式发生冲突.并且可以防止更多松散形式的含糊不清.

实践表明对PTMF的认识很少,而且它们与功能基本不同. f或& f可能是对正常功能的请求.一个不能为非静态成员服务的人.那些真正意味着PTMF的人说是这样添加& X :: part.

原文链接:https://www.f2er.com/c/120070.html

猜你在找的C&C++相关文章