- •Введение
- •1 Концепции объектно-ориентированного программирования
- •1.1 Классы и объекты
- •1.2 Геттеры и сеттеры
- •1.3 Перегрузка методов
- •1.4 Ключевые слова this и super
- •1.5 Метод toString()
- •1.6 Конструкторы
- •1.7 Определение класса в Java
- •1.8 Принципы ООП
- •1.8.1 Абстракция
- •1.8.2 Инкапсуляция
- •1.8.3 Наследование
- •1.8.4 Полиморфизм
- •1.9 Переопределение методов
- •1.10 Подстановка
- •1.11 Апкастинг и даункастинг
- •1.13 Абстрактные классы и интерфейсы
- •1.13.1 Абстрактные классы
- •1.13.2 Интерфейсы
- •2 Типы отношений между классами и объектами
- •2.1 Ассоциация
- •2.2 Агрегация
- •2.3 Композиция
- •2.4 Наследование
- •3 Введение во фреймворк «Коллекции». Обобщения
- •3.1 Коллекции
- •3.2 Перебор элементов коллекций
- •3.3 Обобщения
- •3.3.2 Дженерик-методы и универсальные конструкторы
- •3.3.3 Подстановочные символы (wildcard)
- •4 Потоки ввода-вывода и потоки выполнения. Многопоточное программирование
- •4.1 Потоки
- •InputStream
- •OutputStream
- •Символьные потоки
- •Специализированные потоки
- •Файловые потоки
- •Стандартные потоки ввода-вывода
- •Чтение из стандартного ввода
- •Ввод с консоли
- •Форматированный вывод
- •Класс File
- •Методы класса File
- •4.2 Сериализация и десериализация объектов
- •4.2.1 Сериализация
- •4.2.2 Десериализация
- •4.2.3 Исключение данных из сериализации
- •4.2.4 Сериализация статических полей
- •4.2.5 Сериализация с массивом или коллекцией
- •4.2.6 Сериализация Java с наследованием
- •4.2.7 Сериализация Java с агрегированием
- •4.2.8 SerialVersionUID
- •4.3 Потоки выполнения
- •4.4. Жизненный цикл потока
- •4.5 Многопоточность
- •4.5.1 Главный поток
- •4.5.2 Создание и завершение потоков
- •4.5.3 Завершение потока
- •4.5.4 Управление приоритетами
- •4.5.5 Синхронизация потоков
- •4.5.6 Состояния потока
- •4.5.7 Блокировка
- •5 Лямбда-выражения
- •Заключение
- •Литература
- •Глоссарий
38
2.При такой замене мы можем вызывать методы, определенные в суперклассе, и не можем вызывать методы, определенные только в подклассе.
3.Однако если в подклассе переопределены унаследованные методы из суперкласса, будут вызваны переопределенные версии методов подкласса.
·· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
1.11 Апкастинг и даункастинг
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
Замена объекта суперкласса объектом подкласса называется
апкастингом (upcasting) или приведением к базовому типу.
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
Название действия отражает тот факт, что на UML-диаграмме подкласс изображается ниже суперкласса. Апкастинг всегда безопасен, так как объект подкласса обладает всеми свойствами суперкласса и может делать все, что может делать суперкласс. Компилятор проверяет правильность апкастинга и в противном случае выдает ошибку несовместимости типов.
Например,
Student s1=new GraduateStudent();// Компилятор проверяет, является ли указанное значение значением из подкласса
Student s2=new String();//Ошибка компиляции – несовместимые типы
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
Даункастинг (downcasting) возвращает замещенный объект к
определению через подкласс. Даункастинг – это приведение объекта суперкласса к объекту подкласса.
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
Например,
Student s1=new GraduateStudent(“Иванов”);//апкастинг – безопасен GraduateStudent gs1 = (GraduateStudent)s1;// даункастинг требует яв-
ного приведения типов
Даункастинг требует оператора явного приведения типов в форме префиксного оператора (новый_тип). Даункастинг не всегда безопасен и вызывает ошибку ClassCastException во время исполнения, если объект даункастинга не принадлежит правильному подклассу. Объект подкласса может быть заменен суперклассом, но обратное утверждение неверно.
39
1.12Оператор instanceof
ВJava имеется оператор instanceof типа boolean, который возвращает значение true, если объект является экземпляром данного класса. Проще говоря, оператор instanceof нужен, чтобы проверить, был ли объект, на который ссылается переменная a, создан на основе какого-либо класса B.
Оператор instanceof имеет вид:
a instanceof B;
Другими словами, оператор instanceof вернет значение true, если:
1)переменная а хранит ссылку на объект типа B;
2)переменная a хранит ссылку на объект, класс которого унаследован от B;
3)переменная а хранит ссылку на объект, реализующий интерфейс B. Иначе оператор instanceof вернет значение false.
Простой пример из классов-оберток:
Object o = new Integer(3);
boolean isInt = o instanceof Integer;
isInt будет равно true. Объект, на который ссылается переменная o, является объектом класса Integer.
Integer x = new Integer(22);
boolean isInt = x instanceof Integer;
Объект х является Integer, поэтому результатом будет true.
· · · · · · · · · · · · · · · · · · · · · · · · · |
|
Пример · · · · · · · · · · · · · · · · · · · · · · · · · |
|
|
|
Вернемся к нашим студентам:
public class Main {
public static void main(String[] args) {
// s1, s2, s3 – объекты, т. е. наши тестовые студенты
Student s1 = new Student();
GraduateStudent s2 = new GraduateStudent();
Student s3 = new GraduateStudent();
//проверяем принадлежность объекта к какому-то классу