&foo::function 和 foo::function 有什么区别?
What is the difference between &foo::function and foo::function?
我正在使用linux上的gtkmm库为我的GUI绘制一个简单的菜单。
在下面的代码中,编译器抱怨无法解析地址
sigc::mem_fun(*this, AppWindow::hide)));
^
appwindow.cpp:15:41: note: could not resolve address from overloaded function
但是当我插入&
时,它编译得很好
m_menu_app.items().push_back(MenuElem("Quit",
sigc::mem_fun(*this, &AppWindow::hide)));
这里有什么区别?hide
功能首先不就是一个地址吗?
这是函数到指针转换的确切定义,[conv.func]:
函数类型
T
的左值可以转换为 prvalue 的类型 "指向T
的指针。"结果是指向函数的指针。55
55) 此转换从不适用于非静态成员函数,因为引用非静态成员函数的左值 无法获得。
因此,我们在正常的非成员函数1 中看到的衰减不适用,您需要显式获取地址。
即
void f();
struct A {
void f();
static void g();
};
auto a = f; // Ok: auto deduced as void(*)()
auto b = A::f; // Error: A::f not an lvalue, auto cannot be deduced
auto c = A::g; // Ok: auto deduced as void(*)()
1 或静态成员函数。
对于全局(非成员)函数,函数名称的计算结果为该函数的地址,除非传递给 &
运算符,因此您可以(例如)等效地分配给带有或不带有&
的函数的指针:
int f() {}
int (*pf1)() = f;
int (*pf2)() = &f;
所以,在这种情况下,两者之间真的没有区别。
但是,对于成员函数1,规则略有不同。在这种情况下,需要&
;如果你试图省略&
,代码根本无法编译(假设编译器运行正常,无论如何)。
没有特别的理由一定要这样 - 这只是Bjarne决定事情应该如何。如果他决定希望成员函数的名称计算为指向成员的指针(相当于非成员函数的工作方式),他本可以这样做。
1. 静态成员函数除外,静态成员函数大多像非成员函数。
当函数是类的非静态成员函数时,当表达式中需要指向成员函数的指针时,必须使用形式&ClassName::functionName
。
是类的静态成员函数时,当表达式中需要指向函数的指针时,可以使用ClassName::functionName
和&ClassName;:functionName
。
是全局函数(即非成员)函数时,当表达式中需要指向函数的指针时,可以使用functionName
和&functionName
。
- "error: no matching function for call to"构造函数错误
- 调用专用模板时出错"no matching function for call to [...]"
- 库函数需要一个 std::function<void(void)>,如何传入类函数?
- Confusion: decltype vs std::function
- 为什么 std::function 可以作为 std::not2 的参数?
- 'max'匹配'std::function<const int &(const int &, const int &)>'无过载
- 传递给std::function template的template参数究竟代表什么
- 我知道函数调用中存在歧义.有没有办法调用foo()函数
- 将带有unique_ptr的可变 lambda 传递给 const&std::function
- 绑定派生类方法C++从实例范围之外的分隔 std::function 变量调用
- "no matching function for call to 'Vector::Vector'"错误
- 如何在向量中删除 std::function<void()>?
- 不断"Attempting to reference a deleted function"
- 仅让特定类'Fabric'构造类'Foo'及其所有子类的实例
- 将函数包装器转换为 std::function
- 类型擦除的std::function与虚拟函数调用的开销
- C++ std::function 对于类 exept 的所有实例都是空的(只有 Visual2019 编译器问题)
- 如果模板没有可变参数,则 Lambda 被推导出为 std::function
- &foo::function 和 foo::function 有什么区别?
- 函数中是否有任何内存泄漏,如function(new Foo())