1. Инкапсуляция данных (упрятывание данных, абстрактные типы данных).
То есть определение типов данных и возможных способов манипуляции ими. Классический пример – стек. Задается структура данных (например, одномерный массив) и процедуры помещений в стек, выталкивания из верхушки стека и проверка стека на пустоту. Другие способы доступа к информации стека запрещены. То есть, нельзя, например, обратиться напрямую к какому-то элементу соответствующего массива. Инкапсуляция, четко определяя границы объектов, что «укрупняет» систему и упрощает работу с ней. Впрочем, принципы инкапсуляции сами по себе нашли наилучшее воплощение, среди практических языков, в процедурном языке Ада.
2. Наследование.Совместно с инкапсуляцией наследование составляет два основных принципы ООП. Именно их сочетание и дало качественно новый подход к программированию.
Различные виды отношений между объектами:
1). Генерация is-a “есть некоторый”.
2). Классификация instance of “быть примером”.
3). Агрегацияpart of “быть частью”.
4). Ассоциация member of “быть элементом”.
На практике традиционное программирование для борьбы со сложностью, занимаясь декомпозицией и классификацией, использует отношения «быть частью» - «быть элементом». В ООП прежде всего используются “есть некоторый” - “быть примером”.
Традиционный подход к декомпозиции на примере завода можно представить так
При ООП используется «классификационный» подход:
Стрелками показано отношение «есть некоторый».
Такой подход дает возможность нижестоящим объектам наследовать свойства вышестоящих. В пересчете на программирование – использовать программы, «обслуживающие» вышестоящий объект.
3. Механизм обмена сообщениями. Объекты обмениваются сообщениями. Учитывая те же реалии прямого моделирования можно сказать, что механизм обмена сообщениями может существенно отличаться от механизмов передачи параметров и вызова процедур. Кстати, «передачи параметров» могут быть независимы по времени от «вызовов процедур».
4. Позднее связывание. Позднее связывание - это и методологический и технический принцип, который исходит из того, что решения следует принимать не раньше того момента, когда это необходимо, чтобы учесть сложившуюся на этот момент ситуацию. Мы можем закладывать в алгоритм, скажем, «долларовый эквивалент», а конкретный пересчет произойдет в момент расчета. Или, например, объект 5 может в разных контекстах восприниматься по-разному: как число, строка, символ и т.д., то есть менять тип.
Кстати, позднее связывание - это один из аргументов за режим интерпретации.
В настоящее время многие прикладные языки, прежде всего связанные с интернетом, строятся с оглядкой на ООП. Так что ест надежды.