Инкапсуляция помогает с изменениями программного обеспечения.
Доступный интерфейс класса может оставаться неизменным, а реализация атрибутов и методов может измениться.
Пользователям, использующим класс, не нужно заботиться о том, как реализация фактически работает за интерфейсом.
В программировании такого рода подход обычно называют черным ящиком.
Подумайте о классе, как о черном ящике, который вы не можете видеть внутри, для получения подробной информации о том, как представлены атрибуты или как методы вычисляют результат, но вы предоставляете входные данные и получаете результаты посредством вызова методов.
Так как внутренняя работа не имеет отношения к внешнему миру, это обеспечивает абстракцию, которая эффективно снижает сложность для пользователей класса.
И это увеличивает повторное использование, потому что другому классу нужно знать только правильный метод вызова, чтобы получить желаемое поведение, какие аргументы поставлять в качестве входных данных и что будет отображаться как результат.
Инкапсуляция является ключевым принципом разработки в хорошо написанной программе.
Она поддерживает модульность и простоту работы с программным обеспечением.
Декомпозиция берет целую вещь и делит ее на разные части.
Или, с другой стороны, берет кучу отдельных частей с различными функциональными возможностями и объединяет их вместе, чтобы сформировать целое.
Разложение позволяет вам разложить проблему на части, которые легче понять и решить.
Разделяя вещь на разные части, вы можете более легко разделить обязанности этой вещи.
Общее правило для разложения состоит в том, чтобы посмотреть на разные обязанности чего-то целого и оценить, как вы можете разделить это целое на разные части, каждую со своей конкретной обязанностью.
Это связывает целое с несколькими различными частями.
Иногда целое делегирует конкретные обязанности своим частям.
Например, холодильник делегирует замораживание пищи и хранение этой пищи в морозильной камере.
Так как разложение позволяет создавать четко определенные части, вполне естественно, что эти части являются отдельными.
Целое может иметь фиксированное или динамическое число частей определенного типа.
Если существует фиксированное число, то за время жизни всего объекта он будет иметь именно это количество объектов частей.
Например, холодильник имеет фиксированное количество морозильников, только один.
Это не меняется со временем, но иногда есть части с динамическим числом.
Объект может получить новые экземпляры объектов частей за время его существования.
Например, холодильник может иметь динамическое количество полок с течением времени.
И сама часть может также служить целым, содержащим дополнительные составные части.
В декомпозиции играет роль время жизни всего объекта, а также время жизни объектов частей и то, как они могут соотноситься между собой.
Например, холодильник и морозильник имеют одинаковый срок службы.
И одно не может существовать без другого.
Если вы откажетесь от холодильника, вы также избавитесь от морозильной камеры.
Но срок жизни также может быть не связан.
У холодильника и продуктов питания разные сроки службы. И каждый может существовать независимо.
Также вы можете иметь целые вещи, которые имеют общие части в одно и то же время.
Например, человек, у которого есть дочь в одной семье, а также супруга в другой семье.
Эти две семьи считаются отдельными целыми, но они одновременно имеют одну и ту же общую часть.
Однако иногда совместное использование невозможно.
Например, пищевой продукт в холодильнике не может одновременно находиться в духовке.
В целом, разложение помогает разбить задачу на более мелкие части.
И сложная вещь может быть составлена из отдельных более простых частей.
И важным является понимания – это то, как части относятся к целому, фиксированное или динамическое их число, их время жизни и совместное использование.
Идея объектно-ориентированного моделирования и программирования заключается в создании компьютерного представления концепций в пространстве задачи.
Читать дальше