Wzorzec projektowy kompozyt należy do wzorców strukturalnych. Umożliwia on tworzenie struktur drzewiastych, gdzie podstawową jednostką jest liść ang. Leaf a rozszerzoną kompozyt ang. Composite, przy czym kompozyt można opisać jako swego rodzaju gałąź struktury. Oba te elementy (liść i kompozyt) dziedziczą po wspólnym interfejsie. Sam kompozyt zawiera kontener, który może przechowywać interfejsy, za którymi mogą stać jednostki podstawowe (liście) lub kolejne gałęzie (kompozyty).
Ten wzorzec jest wręcz stworzony do tworzenia np. drzewa dokumentu XML, implementacji algorytmu ONP, tworzenia struktury menu itd. itp. Innymi słowy można go stosować tam, gdzie ma się do czynienia z strukturami drzewiastymi.
Jak widać na poniższym diagramie UML użytkownik używa interfejsu iComponent, który został otrzymany z utworzenia instancji obiektów klas Leaf i Composite. Co ważne klasa Composite agreguje interfejsy iComponent w polu components umożliwiając tym samym dodawanie nowych gałęzi (Composite) i liści (Leaf) do obiektu tej klasy.
Bardzo ważnym elementem jest tutaj również destruktor wirtualny, który niszczy wszystkie elementy utworzonej struktury programu.
Przykładowa implementacja wzorca projektowego kompozyt w C++
Przykład pokazujący jak można stworzyć drzewo menu programu za pomocą tego wzorca.
===============================
Menu
===============================
===============================
File
===============================
Open
Save
===============================
Edit
===============================
Copy
Paste
Duplicate
===============================
Delete Menu
===============================
===============================
Delete Edit
===============================
Delete leaf: Duplicate
Delete leaf: Paste
Delete leaf: Copy
===============================
End of delete Edit
===============================
===============================
Delete File
===============================
Delete leaf: Save
Delete leaf: Open
===============================
End of delete File
===============================
===============================
End of delete Menu
===============================