- •Особенности языка 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
Понятие среды выполнения Java
Среда выполнения Java Runtime Environment (JRE) поставляется в составе JDK. Виртуальная машина Java (JVM) является основой JRE. Функции JVM выполняет модуль java.exe — интерпретатор языка Java.
Переносимость языка Java
JVM обеспечивает независимость откомпилированных Java-программ от аппаратной платформы и операционной системы (ОС). Именно благодаря JVM язык Java является переносимым (мобильным).
На языке Java можно создавать переносимые приложения, т.е. приложения, не требующие при переносе с платформы на платформу изменения исходного текста и перетрансляции.
Независимость от программного интерфейса ОС, который неодинаков для разных платформ, обеспечивается использованием набора стандартных библиотек классов Java, называемых
пакетами.
Java API (Application Programming Interface — интерфейс прикладного программирования) — это набор сгруппированных в пакеты классов, разработанных Sun Microsystems для работы с языком Java.
Пакеты содержат все необходимые средства для организации пользовательского интерфейса, работы с файлами, сетевыми соединениями и т.д. Приложение Java, выполняемое JVM, не обращается напрямую к программному интерфейсу ОС. Программисты могут не беспокоиться о различиях в реализации программного интерфейса конкретных ОС.
Внутренняя реализация библиотек JVM зависит от платформы, но все загрузочные модули библиотек поставляются в готовом виде с JVM.
Высокая производительность языка Java
Программа, выполняемая в режиме интерпретации, по определению работает существенно медленнее, чем программа, полученная в виде машинного кода после компиляции и затем запущенная на выполнение.
Разработчики Java с целью повышения производительности внесли в платформу Java 2 несколько дополнений.
1)Компиляторы JIT (Just-In-Time), появившиеся в JDK 1.2, являются частью современных JVM (в том числе встраиваемых в Web-браузеры). Они обеспечивают компиляцию байт-кода в машинный код в
реальном времени при выполнении программы («на лету»). JIТ требуют дополнительных затрат ресурсов памяти для хранения откомпилированного кода. Когда компилятор JIT впервые встречает фрагмент байт-кода, то он передаёт его интерпретатору, а также компилирует и сохраняет в виде машинного кода. Если программа вновь обращается к этому фрагменту и компилятор встречает его повторно, то он уже не вызывает интерпретатор, а обеспечивает непосредственное выполнение машинного кода.
2)Виртуальная машина Java HotSpot используется, начиная с JDK 1.3. В отличие от JIT-компиляторов, преобразовывает в машинный код только те фрагменты байт-кода, которые влияют на производительность. HotSpot производит оптимизацию кода во время его выполнения. В результате приложения Java работают с производительностью, сравнимой с производительностью обычных приложений.
3)Существуют компиляторы исходного кода или байт-кода Java в машинные коды известных компьютерных платформ — native-компиляторы («родные»). Разрабатываются сторонними фирмами, например IBM, GNU.
Примером native-компилятора является IBM HPJC (High Performance Java Compiler). Такие компиляторы позволяют создавать высокопроизводительные приложения Java, которые, однако, теряют такие преимущества Java, как переносимость и безопасность.
3