- •Особенности языка Java
- •История Java
- •Характерные особенности Java
- •Разработка и выполнение Java приложения:
- •Понятие среды выполнения Java
- •Переносимость языка Java
- •Высокая производительность языка Java
- •Типы Java-приложений
- •Автономное (самостоятельное) приложение – application
- •Апплет – applet
- •Комбинированное приложение
- •Сервлет – servlet
- •Мидлет – midlet
- •Различия между автономными приложениями и апплетами
- •Автономное приложение
- •Апплет
- •Этапы жизненного цикла апплета
- •Этапы жизненного цикла в соответствии со стандартом Sun:
- •Этап инициализации
- •Этап запуска
- •Этап останова
- •Этап уничтожения
- •Этап рисования (перерисовки) окна апплета
- •Отличия Java от C++
- •Конструкторы классов
- •«Сборщик мусора»
- •Типы данных в Java
- •Простые типы
- •Ссылочные (объектные) типы
- •Строки в Java
- •Массивы в Java
- •Классы в Java
- •Особенности реализации
- •Пакеты
- •Управление доступом к элементам класса
- •Поля класса
- •Методы
- •Перегрузка и переопределение методов
- •Ключевые слова THIS и SUPER
- •Интерфейсы в Java
- •Понятие Java API
- •Пакеты ядра Java API (в JDK 1.0):
- •Развитие ядра Java API (в новой версии JDK и в Java 2)
- •Основные понятия AWT
- •Компоненты
- •Контейнеры
- •Компоновки. Менеджеры компоновки
- •События
- •События. Обработка событий
- •Иерархия классов-событий
- •Семантические события и их источники-компоненты AWT
- •Модель делегирования событий
- •Методы, объявленные в интерфейсах для семантических событий
- •Способы реализации блока прослушивания событий от AWT-компонента
- •Понятие класса-адаптера
- •Комбинированное приложение Java. Обработка события WindowEvent
- •Исключения в Java и их обработка
- •Иерархия классов исключений
- •Различия между исключениями Exception и ошибками Error
- •Организация обработки исключений в программе
- •Используемые операторы:
- •Как правильно организовывать обработку исключений
- •Понятия процесса и потока
- •Конструкторы класса Thread
- •Наиболее важные методы класса Thread
- •Способы создания потоков
- •Синхронизация потоков
- •Когда следует использовать синхронизацию потоков?
- •Механизм блокировки объекта
- •Способы использования ключевого слова synchronized
- •Синхронизированные методы
- •Оператор synchronized
- •Преимущества оператора synchronized:
- •Взаимодействие потоков: использование методов wait(), notify(), notifyAll()
- •Стандартные образцы кода использования методов
- •Поток-диспетчер событий AWT
- •Потоки и исключения
- •О группах потоков
- •Технология компонентного программирования JavaBeans
- •Понятие технологии компонентного программирования
- •Этап компиляции
- •Этап разработки
- •Этап создания приложения
- •Этап выполнения
- •Понятие компонентной модели
- •Основные требования к классам Bean-компонентов
- •Соглашения об именах
- •Соглашения об именах для свойств
- •Соглашения об именах для событий
- •Соглашения об именах для методов
- •Использование событий для управления свойствами
- •Связанные свойства
- •Преобразование обычного свойства в связанное
- •Ограниченные свойства
- •Преобразование обычного свойства в ограниченное
- •Ввод-вывод в Java: основные понятия
- •Основные группы классов и интерфейсов пакета java.io
- •Фильтрованные потоки
- •Буферизированные потоки
- •Принципы работы Buffered-потоков
- •Входные потоки
- •Выходные потоки
- •Канальные потоки
- •Синхронизация потоков данных
- •Понятие отражения (рефлексии)
- •Класс java.lang.Class
- •Классы пакета java.lang.reflect
- •Понятие интроспекции
- •Понятие сериализации
- •Обеспечение сериализуемости Bean
- •Выполнение базовой сериализации
- •Пример с сериализацией (см. SerializationDemo.java)
- •Настройка сериализации
- •Методы readObject и writeObject
- •Интерфейс Externalizable
- •Создание экземпляров сериализованных Bean
- •Приложение
- •// Файл HelloApplet.java
- •// Файл MyApplet.java
- •// Файл StringDemo.java
- •// Файл ConstrDemo.java
- •// Фрагменты файла AnimBallsPlus.java
Скачано с сайта http://ivc.clan.su
Интроспекция — процесс анализа компонента компоновщиком с целью определения его возможностей. Она позволяет визуальной среде предоставить разработчику информацию о компонентах (их свойствах, методах, событиях) для настройки и связывания компонентов.
ВJavaBeans интроспекция поддерживается механизмом отражения (рефлексии), который обеспечивается пакетом java.lang.reflect и элементами класса java.lang.Class.
Устойчивость (сохраняемость) — способность сохранять состояние настроенных компонентов в дисковой памяти и позднее восстанавливать их.
ВJavaBeans устойчивость поддерживается механизмом сериализации и десериализации.
(Сериализация — преобразование объектов в поток байтов с целью сохранения на диске.)
JavaBeans сохраняются в файлах .ser.
Обработка событий обеспечивает взаимодействие компонентов и обмен сообщениями между
ними.
Компоновщики предоставляют разработчику визуальные средства для связывания компонентов, т.е. для соединения механизма запуска события в одном компоненте с методом его обработки в другом компоненте.
ВJavaBeans обработка событий обеспечивается моделью делегирования событий. Компонент, генерирующий событие, называется источником события, компонент, получающий и реагирующий на событие, — блоком прослушивания (приемником) события.
Упаковка компонентов
Классы и ресурсы компонентов (ресурсы — возможны файлы .ser, файлы изображений, звуковые, пиктограмм и т. п.) упаковываются в специальные архивы, позволяющие упростить и ускорить процессы поставки и установки компонентов в среде визуального проектирования.
ВJavaBeans упаковка обеспечивается jar-технологией (Java ARchive). Файл .jar содержит специальный тип zip-файла. Пакет java.util.zip содержит классы и методы для обработки таких файлов. Утилита jar в JDK используется для генерации jar-файлов и извлечения файлов из архивов.
Распределенная обработка данных
— это способность компонентов, размещенных на разных компьютерах сети, к взаимодействию. Компоненты JavaBeans подходят для распределенной обработки данных, так как имеют доступ к
обычным механизмам, используемым приложениями Java для сетевых коммуникаций. С технологией JavaBeans может применяться технология RMI (Remote Method Invocation) — удаленный вызов методов. RMI дает возможность объектам, размещенным на различных виртуальных Java-машинах, взаимодействовать путем вызова методов друг друга. Следует отметить, что Bean-компоненты, загруженные из сети, подчиняются правилам безопасности, предусмотренным для апплетов.
Основные требования к классам Bean-компонентов
Bean-компонент — это основанный на спецификации JavaBeans элемент программного обеспечения, который предназначен для повторного использования и которым можно управлять визуально в интегрированной среде разработки.
Если класс Java соответствует спецификации JavaBeans, он является классом компонента.
Класс Bean-компонента должен удовлетворять следующим требованиям.
1.Способность к инициализации нового экземпляра (объекта). Компоненты JavaBeans нельзя создавать на основе интерфейсов и абстрактных классов.
2.Наличие принимаемого по умолчанию конструктора. Например, если класс называется MyBean,
необходимо, чтобы он имел конструктор без параметров MyBean().
3.Возможность сериализации. В компоненте должен быть реализован интерфейс Serializable (или Extemalizable), который позволяет преобразовывать содержимое компонента в поток байтов.
35