我有一个自定义容器(“主题”),许多其他类都在观察它。更改容器后,将在更改后将通知推送给所有观察者。例如,对于调整大小,流程如下

std::vector<double> vec;

void resize(size_t n)
{
    vec.resize(n);          //first resize
    notify(Event::RESIZE);  //afterwards inform observers about the resize event
}

现在,当我通过引用访问更改容器的元素时,看不到明显的方法来进行通知:
double& operator[](size_t i)
{
    notify(Event::CHANGE_ELEMENT);  //no way to notify afterwards, so notify before
    return vec[i];
}

因此,当我将元素更改为
containerObject[2] = 1.1;

观察者会收到有关旧状态的通知,该状态仅在通知后更新。

是否有解决方法(不是使用setter方法)?

最佳答案

进行某种辅助类,只需将通知推送到销毁即可。

struct MyHelper
{
    //This is may be a friend of your container

    MyHelper(std::size_t index, MyCustomContainer& ref)
     : _index(index), _ref(ref)
    {  }

    ~MyHelper()
    { notify(Event::CHANGE_ELEMENT); }

    double& operator=(double rhs)
    { _ref._vec[_index] = rhs; }

private:
    std::size_t _index;
    MyCustomContainer _ref;
};

您可以在操作员中执行以下操作:
MyHelper MyCustomContainer::operator[](size_t i)
{
    MyHelper m(i, *this);
    return m;

    // MyHelper Destructor called
}

试试online!

09-05 06:46