官术网_书友最值得收藏!

The mediator pattern

In many cases, when we design and develop software applications, we encounter many scenarios where we have modules and objects that have to communicate with one another. The easiest approach would be to make them in such a way that they know each other and can send messages directly.

However, this might create a mess. If we imagine, for example, a communication app in which each client has to connect to another one, it doesn't make sense for a client to manage many connections. A better solution would be to connect to a central server and for the server to manage the communication between the clients. The client sends the message to the server and the server keeps the connection active to all the clients, and it can broadcast messages to all required recipients.

Another example is where a specialized class is required to mediate between different controls, such as buttons, dropdowns, and list controls, in a graphical interface. For example, the graphical controls in a GUI can hold a reference to each other in order to invoke their methods reciprocally. But obviously, this will create an extremely coupled code in which each control depends on all the others. A better approach would be to make the parent responsible for broadcasting messages to all the required controls when something needs to be done. When something modifies in a control, it will notify the window, which will check which controls need to be informed and then inform them.

主站蜘蛛池模板: 青铜峡市| 张北县| 老河口市| 呈贡县| 日喀则市| 东光县| 广元市| 高碑店市| 余庆县| 鹤峰县| 赤水市| 呈贡县| 交口县| 宽甸| 原阳县| 花莲县| 渑池县| 拉萨市| 临沭县| 西昌市| 吉木乃县| 沁阳市| 潼南县| 迁安市| 龙南县| 长武县| 延边| 那曲县| 寿光市| 安陆市| 临清市| 拜泉县| 宜州市| 开封县| 邢台市| 西安市| 云龙县| 砚山县| 绵阳市| 浦东新区| 临城县|