首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否有一个容器用于对发行者-订阅者关系进行建模,并对两者进行快速查找?

是否有一个容器用于对发行者-订阅者关系进行建模,并对两者进行快速查找?
EN

Stack Overflow用户
提问于 2021-02-23 16:26:36
回答 1查看 68关注 0票数 3

我有一个出版商-订阅者关系,我想建模。发布服务器可以有多个订阅服务器,但每个订阅服务器只能从单个发布服务器获取数据。我认为矢量地图对此是有益的:

代码语言:javascript
复制
std::map<publisher, std::vector<subscriber>>

发布服务器查找、插入和删除速度快,用户插入速度快,并且很容易获得发布服务器的所有订阅服务器。但是订阅者查找和从地图中删除是很麻烦的。它需要迭代所有发布者,直到找到该订阅服务器为止。我仍然想要一种简单的方式来迭代所有订阅者,理想情况下没有双循环。

我想要一个具有这些属性的容器,其中每个操作都是一个函数调用,或者在适当的情况下循环:

  • 查找、插入、删除发布者/订阅者。O(1)或O(lg N);N=出版商/订户的publishers/subscribers
  • Iteration数。O(N);N=单个发布服务器的订阅publishers/subscribers
  • Iteration数。查找+ O(N);N=该发布服务器的订阅者数量。

是否有现成的容器可以做到这一点,或者我必须做一个自定义的容器?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-23 16:57:29

我建议:

代码语言:javascript
复制
struct SubscriptionRecords {
    std::unordered_map<publisher, std::unordered_set<subscriber>>
        subscribers;
    std::unordered_map<subscriber, publisher>
        subscriptions;
};

然后是一些示例方法:

代码语言:javascript
复制
void add_subscription(publisher p, subscriber s) {
    auto res = self->subscriptions.insert(s);
    assert(res->second);  // At most one subscription.
    self->subscribers[p].insert(s);
}

void remove_subscriber(subscriber s) {
    auto sp = self->subscriptions.find(s);
    if (sp != self->subscriptions.end()) {
        self->subscribers[*sp].erase(s);
        self->subscriptions.erase(sp);
    }
}

和类似的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66337091

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档