c++ - std::function不起作用,但是普通的旧函数指针起作用-为什么?

标签 c++ pointers std function-pointers std-function

我想制作一个将std::function作为参数的函数,并在内部调用该函数:

void handleCollision(std::function<void(const Entity&)>& resolveCollision, const Entity& block) {
    if (playerInRangeOf(block) && playerIntersects(block)) {
        resolveCollision(block);
    }
}

和调用方(在同一类中):
for (auto&& block : blocks) {
    handleCollision(resolveCollisionAxisX, block);
}

错误:
Reference to non-static member function must be called
error: no matching function for call to 'StateGame::handleCollision(<unresolved overloaded function type>, Block&)'
handleCollision(resolveCollisionAxisX, block);
                                            ^

但是,如果我遵循C风格的函数指针:
void handleCollision(void (StateGame::*resolveCollision)(const Entity&), const Entity& block) {
    if (playerInRangeOf(block) && playerIntersects(block)) {
        (this->*resolveCollision)(block);
    }
}

然后它确实可以正常工作(调用者是相同的)。

如何使std::function工作?旁注:我不想使任何内容静态化。

最佳答案

将其包装在lambda中,更换

handleCollision(resolveCollisionAxisX, block)


[this](const Entity& e){
   this->resolveCollisionAxisX(e);
}

还要将std::function<void(const Entity&)>&替换为std::function<void(const Entity&)>const std::function<void(const Entity&)>&

关于c++ - std::function不起作用,但是普通的旧函数指针起作用-为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59591309/

相关文章:

c++ - QT中的Q_OBJECT(对vtable xxx的 undefined reference )

pointers - 简单的 Go 指针解释

c++ - 如何制作 std::weak_ptr 的 c++11 std::unordered_set

c++ - Qt Concurrent 或 std::async 用于新代码?

c++ - 如何仅针对键的子集有效地比较 C++ 中的两个字符串映射

c++ - 编译错误: Use of a deleted function

c++ - 使用继承命名空间的模板类进行名称查找

c - 函数指针数组指针用作函数的返回值

C代码中的编译时错误[从函数返回数组指针]

c++ - 模板参数推导失败,使用函数指针作为参数