当前位置: 首页 > news >正文

通州网站建设公司网页设计

通州网站建设公司,网页设计,自己做网站怎么加定位,哈尔滨做网站费用在组合模式中,为了实现同一层上部件的有序性,可以采取以下几种设计方法: 1. 使用有序集合 使用有序集合(如 std::list、std::vector 或其他有序容器)来存储和管理子部件。这种方法可以确保子部件按照特定顺序排列&am…

在组合模式中,为了实现同一层上部件的有序性,可以采取以下几种设计方法:

1. 使用有序集合

使用有序集合(如 std::liststd::vector 或其他有序容器)来存储和管理子部件。这种方法可以确保子部件按照特定顺序排列,并且可以通过索引访问。

示例代码:
#include <vector>
#include <iostream>class Component {
public:virtual void operation() = 0;virtual ~Component() {}
};class Leaf : public Component {
public:void operation() override {std::cout << "Leaf operation" << std::endl;}
};class Composite : public Component {
public:void operation() override {for (auto& component : components) {component->operation();}}void add(Component* component) {components.push_back(component);}void remove(Component* component) {components.erase(std::remove(components.begin(), components.end(), component), components.end());}private:std::vector<Component*> components;
};int main() {Composite* root = new Composite();root->add(new Leaf());root->add(new Leaf());root->add(new Leaf());root->operation(); // 输出 "Leaf operation" 三次delete root;return 0;
}

在这个示例中,Composite 类使用 std::vector 来存储子部件,确保它们按添加顺序排列。

2. 使用索引管理

在添加子部件时,可以指定一个索引位置,从而控制子部件的排列顺序。

示例代码:
#include <vector>
#include <iostream>class Component {
public:virtual void operation() = 0;virtual ~Component() {}
};class Leaf : public Component {
public:void operation() override {std::cout << "Leaf operation" << std::endl;}
};class Composite : public Component {
public:void operation() override {for (auto& component : components) {component->operation();}}void add(Component* component, int index) {if (index < 0 || index > components.size()) {index = components.size();}components.insert(components.begin() + index, component);}void remove(Component* component) {components.erase(std::remove(components.begin(), components.end(), component), components.end());}private:std::vector<Component*> components;
};int main() {Composite* root = new Composite();root->add(new Leaf(), 0); // 插入到位置 0root->add(new Leaf(), 1); // 插入到位置 1root->add(new Leaf(), 0); // 插入到位置 0,原来的部件后移root->operation(); // 输出 "Leaf operation" 三次,顺序为新插入的第一个,然后是原来的第一个,最后是原来的第二个delete root;return 0;
}

在这个示例中,add 方法允许你指定插入子部件的索引位置,从而控制子部件的排列顺序。

3. 使用排序标准

如果你需要更复杂的排序逻辑(例如按某些属性排序),可以在添加子部件后对集合进行排序。

示例代码:
#include <vector>
#include <algorithm>
#include <iostream>class Component {
public:virtual void operation() = 0;virtual ~Component() {}virtual int getPriority() const = 0; // 排序标准
};class Leaf : public Component {
public:Leaf(int priority) : priority(priority) {}void operation() override {std::cout << "Leaf operation with priority " << priority << std::endl;}int getPriority() const override {return priority;}
private:int priority;
};class Composite : public Component {
public:void operation() override {std::sort(components.begin(), components.end(), [](Component* a, Component* b) {return a->getPriority() < b->getPriority();});for (auto& component : components) {component->operation();}}void add(Component* component) {components.push_back(component);}void remove(Component* component) {components.erase(std::remove(components.begin(), components.end(), component), components.end());}int getPriority() const override {return 0; // 组合节点的优先级}private:std::vector<Component*> components;
};int main() {Composite* root = new Composite();root->add(new Leaf(3));root->add(new Leaf(1));root->add(new Leaf(2));root->operation(); // 输出 "Leaf operation with priority 1", "Leaf operation with priority 2", "Leaf operation with priority 3"delete root;return 0;
}

在这个示例中,Leaf 类有一个 priority 属性,Composite 类在执行操作时会根据优先级对子部件进行排序,从而实现有序性。

总结

通过使用有序集合、索引管理或排序标准,你可以在组合模式中实现同一层上部件的有序性。这些方法可以根据具体需求灵活选择,以满足不同的排序和组织要求

http://www.fp688.cn/news/156882.html

相关文章:

  • 网页设计网站方案青岛网络推广公司哪家好
  • 做耳鼻喉医院网站多少钱b2b多平台一键发布
  • 自建网站做电商seo流量工具
  • 怎样在设计网站做图赚钱优化好搜移动端关键词快速排名
  • 七个2wordpress焦作关键词优化排名
  • 网站免费申请注册市场营销毕业后做什么工作
  • 网站索引量百度百度一下就知道
  • 汕头seo网站管理视频号链接怎么获取
  • 网站建设多少钱合适seo推广 课程
  • 深圳优定软件网站建设查域名
  • 网站程序系统四川seo技术培训
  • 静态学校网站做毕业设计互联网营销的十五种方式
  • 加入网站帮忙做网站品牌宣传推广文案
  • 请人做外贸网站应注意什么微信营销典型案例
  • 网站开发的系统需求百度站内搜索的方法
  • 网站快速搜索有什么可以做推广的软件
  • 官方网站建设实训心得软件推广平台有哪些
  • 建筑建材网站设计费用营销qq下载
  • 莆田网站建设电话seo页面优化的方法
  • .湖南省建设厅规范网站厨师培训
  • 苏州招聘网站建设培训机构在哪个平台找
  • 聊城冠县网站建设seo专员简历
  • 建设银行招聘社会招聘网站参考消息今天新闻
  • 安阳汤阴县网站建设北京seo工程师
  • 新乡市网站建设seo具体是什么
  • me微擎怎么做网站搜索百度网页版
  • 深圳企业网站开发临沂网站建设优化
  • 慢慢来做网站多少钱推广方案有哪些
  • 做社交网站多少钱临沂做网络优化的公司
  • 洛阳市app网站开发公司电话竞价托管外包费用