Evgenii Legotckoi
Evgenii LegotckoiSept. 25, 2018, 5:46 a.m.

Structural Design Patterns - Composite

Goals

  • Arrange objects into tree structures to represent entire parts of the hierarchy. The linker allows clients to treat individual objects and compositions of objects in the same way.
  • Recursive composition
  • "Directories contain entries, each of which can be a directory."
  • One-to-many hierarchy representation

Problems

An application needs to manipulate a hierarchical collection of "primitive" and "composite" objects. The processing of a primitive object is handled in one way, while the processing of a composite object can be handled in different ways. Requesting the type of an object before processing is not desirable.


Discussion

Define an abstract base class (component) that defines the behavior that should be performed in the same way for all primitive and composite objects. Subclass - primitive and composite classes. Each composite object "connects" only to the abstract type of the Component, since it manages its "children".

Use this pattern whenever you have "composites that contain components, each of which can be composited".

Child management methods [ addChild() , removeChild() ] should normally be defined in the Composite class. Unfortunately, the desire to use primitives and composite objects alike requires that these methods be moved to the abstract Component class.

Structure

Composers containing Components, each of which can be composite.

Menus containing menu items, each of which can be a menu.

Row-column GUI layout managers, which contain widgets, each of which can be a row-column GUI layout manager.

Directories containing files, each of which can be a directory.

Containers containing elements, each of which can be a container.

Example

The composer organizes objects into tree structures and allows clients to process individual objects and compositions individually. Although this example is abstract, the arithmetic expressions are Composites. An arithmetic expression consists of an operand, an operator (+ - * /), and another operand. The operand can be a number or another arithmetic expression. So 2 + 3 and (2 + 3) + (4 * 6) are valid expressions.

Control List

  1. Make sure your problem is in representing tree-like hierarchical relationships.
  2. Consider an example: "Containers containing devices, each of which can be a container." Divide them into primitive classes and container classes.
  3. Create an interface to represent the simplest node with the minimum necessary methods makes your containers and primitives interchangeable. It must specify behavior that must be performed in the same way in all primitives and containers.
  4. All container classes implement the interface.
  5. All container classes declare a one-to-many relationship with an interface.
  6. Container classes use polymorphism to delegate their container objects.
  7. Child management methods [ addChild() , removeChild() ] should normally be defined in the Composite class. Unfortunately, the desire to treat primitives and layouts uniformly may require these methods to be promoted to the abstract Component class.

Rules of thumb

  • The composer and decorator have similar structure diagrams, reflecting the fact that both rely on recursive composition to organize an open number of objects.
  • The layout can be moved using an iterator. Visitor can apply an operation on layouts. The linker can use Chain of Responsibility to allow components to access global properties through their parent. It can also use a Decorator to override these properties piece by piece. It can use an Observer to bind one object structure to another and state so that the component changes its behavior as the state changes.
  • The linker may allow you to create a pick from smaller parts using recursive composition.
  • The decorator is for adding properties to objects without a subclass. Hence, the layout and decorator are often used together.
  • Flyweight is often combined with Composite to implement common leaf nodes.
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

Comments

Only authorized users can post comments.
Please, Log in or Sign up
ОК

Qt - Test 001. Signals and slots

  • Result:47points,
  • Rating points-6
A
  • Alena
  • Jan. 19, 2025, 7:41 p.m.

C++ - Test 005. Structures and Classes

  • Result:58points,
  • Rating points-2
OI

C++ - Test 001. The first program and data types

  • Result:40points,
  • Rating points-8
Last comments
ИМ
Игорь МаксимовNov. 22, 2024, 7:51 p.m.
Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii LegotckoiOct. 31, 2024, 9:37 p.m.
Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZEOct. 19, 2024, 3:19 p.m.
Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь МаксимовOct. 5, 2024, 2:51 p.m.
Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas5July 5, 2024, 6:02 p.m.
QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Now discuss on the forum
n
nklyJan. 3, 2025, 10:52 a.m.
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
MarselAug. 16, 2023, 9:26 p.m.
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii LegotckoiJune 24, 2024, 10:11 p.m.
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey1Nov. 15, 2024, 2:04 p.m.
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProjectJune 4, 2022, 10:49 a.m.
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

Follow us in social networks