У меня есть простой тест, в котором я пытаюсь связать аргумент weak_ptr с глобальной функцией, которая принимает weak_ptr и вызывает метод, если вспомогательный указатель все еще действителен.
Кажется, это работает, когда я создаю лямбду со слабым указателем. Это также работает, если я вызываю глобальный метод напрямую с параметром weak_ptr. Однако, если я заранее привяжу глобальную функцию к weak_ptr, она, похоже, не сработает. Следующий упрощенный код иллюстрирует вопрос.
Я должен упустить что-то простое. Любые подсказки?
#include <iostream>
#include <functional>
#include <algorithm>
#include <memory>
using namespace std;
class MyValue : public enable_shared_from_this<MyValue>
{
public:
MyValue (int i)
{
value = i;
}
~MyValue()
{
}
int getValue() { return value; }
void printValue() { cout << value << endl; }
private:
int value;
};
void callWeakFunction (weak_ptr<MyValue> weakValue)
{
shared_ptr<MyValue> strongPtr = weakValue.lock();
if (strongPtr)
{
strongPtr->printValue();
}
else
{
cout << "Sorry, your backing pointer is gone" << endl;
}
}
int main()
{
weak_ptr<MyValue> weakValue;
// Try binding a global function to the weak pointer, doesn't seem to work
function<void()> weakPrintValue = bind(callWeakFunction, weakValue);
#if 0
// Create a lambda - this works fine
function<void()> weakPrintValue ([&weakValue]()
{
shared_ptr<MyValue> ptr = weakValue.lock();
if(ptr)
{
ptr->printValue();
}
else
{
cout << "Sorry, backing pointer is gone" << endl;
}
});
#endif
{
shared_ptr<MyValue> value = make_shared<MyValue>(7);
weakValue = value;
// Backing pointer is present
weakPrintValue(); // This does not work, but callWeakFunction (weakValue) works fine
}
// No backing pointer
weakPrintValue();
}
Результирующий вывод:
Sorry, your backing pointer is gone
Sorry, your backing pointer is gone
Ожидается, что первое weakPrintValue напечатает значение (7)