Java 1999

Алексей Федоров

Java: архитектура и интерфейсы

  Технология Java

  Платформа Java 2

  Java 2 в деталях

    Средства разработки на Java

      Базовые утилиты

      RMI-утилиты

      Средства для локализации приложений

      Средства для защиты приложений

      IDL-утилиты

    Набор Java-библиотек и базовых классов

      Abstract Windowing Toolkit

      Swing

      Java 2D

      Drag and Drop

      Accessibility

      Апплеты

      JavaBeans

      Java Media Framework

      Поддержка звука

      Разработка корпоративных приложений

        Доступ к базам данных

        Поддержка распределенных объектов

        Распределенные объекты и CORBA

        Сервисы имен и каталогов

        Электронная почта

        Enterprise JavaBeans

         Сервлеты

  Это еще не все

  Приложение: Интерфейсы Java 2 API

Предлагаем вашему вниманию обзор технологии Java, в котором мы рассмотрим основные тенденции развития этого языка, платформы, существующие программные интерфейсы, средства разработки, компоненты и средства их создания, а также познакомимся с использованием Java при создании корпоративных решений.

Данный обзор будет состоять из следующих частей:

  • Java: архитектура и интерфейсы (публикуется в этом номере)
  • Средства разработки на Java — часть 1
  • Средства разработки на Java — часть 2
  • Компоненты JavaBeans
  • Создание компонентов JavaBeans
  • Java для корпоративных решений

Java: архитектура и интерфейсы

Многим нашим читателям наверняка уже известно, что язык Java был разработан фирмой Sun , как платформенно-независимый, переносимый, объектно-ориентированный язык для Internet и Intranet . Я не вижу особого смысла перечислять преимущества языка, его отличия от C ++ — это уже описано в десятках книг и сотнях публикаций, как за рубежом, так и в нашей стране. Здесь мы остановимся на том, что представляет собой платформа Java сегодня, из каких компонентов она состоит и какие средства, доступны для разработчиков. Таким образом, по завершении данного цикла вы должны будете получить достаточно четкое представление о том, что предлагает фирма Sun , какими средствами разработки можно пользоваться, какие существуют компоненты и средства для их создания и как с помощью Java можно создавать корпоративные решения.

В начало

В начало

Технология Java

Технология Java обеспечивает разработчиков основой для создания решений, при разработке которых не нужно задумываться об операционной системе и аппаратной платформе, на которых эти решения будут функционировать. Часто используемое выражение «Написано однажды — работает везде» лучшим образом характеризует основное назначение этой технологии. Независимость от платформы достигается за счет того, что уникальные характеристики каждой из поддерживаемых Java 2 платформ, реализованы в виде оболочки, называемой Java Runtime Environment (JRE). Во время создания приложения разработчик пишет код на языке Java так, как если бы в мире была бы всего одна программно/аппаратная платформа. Компилятор языка Java преобразует код в последовательность байт-кодов, которая будет выполняться на одной из платформ в рамках JRE.

Java Runtime Environment содержит специальные средства проверки кода, обеспечивающие надежность и защищенность программ, загрузчик классов, который динамически загружает классы в процессе выполнения и виртуальную машину Java (Java VM), которая выполняет последовательность байт-кодов, взаимодействую с конкретной операционной системой. Такой подходт освобождает разработчика от необходимости обращать внимания на специфику какой-то конкретной операционной системы и позволяет внедрять Java-приложения на более чем одной платформе. Компоненты Java Runtime Environment показаны на следующей диаграмме.

То, что язык Java за короткое время стал одним из самых популярных коммерческих объектно-ориентированных языков программирования, помогает распространению технологии Java и подтвержается тем, что в настоящее время этот язык использует около 1 млн. разработчиков (80% из них создает кросс-платформенные приложения), продукты для Java выпускают сотни фирм, а число копий JDK , загруженных с сайта фирмы Sun , превысило 2.5 млн.

В начало

В начало

Платформа Java 2

Платформа Java 2 (Java Development Kit 1.2), объявленная фирмой Sun в декабре 1998 года, представляет собой физическую реализацию технологии Java . Собственно говоря, она заключена в небольшом по объему файле (доступном на нашем CD-ROM) и состоит из следующих основных компонентов:

  • Средства разработки на Java — редактор, компилятор, отладчик и средство для документации JavaAPI
  • Богатый набор Java-библиотек и базовых классов (foundation classes), которые используются для создания графических интерфейсов, доступа к базам данных, реализации сетевых функций, разработки приложений, работающих с несколькими языками и т.п.
  • Java 2 Runtime Environment — средство для динамической загрузки Java-классов, их проверки и выполнения Java-байт-кода.
Архитектура платформы Java 2 показана на следующей диаграмме.

Изначально, Sun выпустила Java 2 Runtime Environment для следующих платформ: Solaris, Windows NT Server 4.0 и Windows 95/98. В ближайшие месяцы поставщики других платформ выпустят соответствующие JRE . Таким образом, Java 2 будет реализована на следующих платформах:

AIX Digital UNIX HP-UX
IRIX Linux Mac OS
NetWare OpenServer OpenVMS
OS/2 OS/390 RISC-OS
Solaris Windows 95 Windows 98
Windows NT Windows NT-Alpha (DEC) UnixWare
В начало

В начало

Java 2 в деталях

Давайте рассмотрим состав Java 2 более подробно. Мы выделили три основных компонента — средства разработки на Java , набор Java-библиотек и базовых классов и Java 2 Runtime Environment.

Средства разработки на Java

В состав JDK 1.2 входит большое число утилит, которые можно подразделить на несколько категорий:

  • Базовые утилиты
  • RMI-утилиты
  • Средства для локализации приложений
  • Средства для защиты приложений
  • IDL-утилиты
В начало

В начало

Базовые утилиты

Утилиты, относящиеся к этой категории, служат основой Java Development Kit . Они используются для компиляции и отладки создаваемых Java-приложений. К базовым утилитам относятся:

javac Компилятор языка Java
java Загрузчик Java-приложений. Используется и в стадии разработки, и в стадии внедрения приложений
javadoc Генератор документации для API
appletviewer Утилита для запуска и отладки приложений без использования web-браузера
jar Утилита для управления Java Archive (JAR)-файлами
jdb Отладчик Java-приложений.
javah Генератор заголовочных файлов и заголушек для языка C
javap Дизассемблер Java-классов
extcheck Утилита для обнаружения конфликов между JAR-файлами
В начало

В начало

RMI-утилиты

Утилиты, относящиеся к этой категории, используются для создания приложений, взаимодействующих между собой по Internet или другим типам сетей. К таким утилитам относятся:

rmic Утилита для генерации заглушек и скелетов для удаленных объектов
rmiregistry Утилита для регистрации удаленных объектов
rmid Средство системной активации RMI
serialver Возвращает serialVersionUID .для данного класса
В начало

В начало

Средства для локализации приложений

К средствам для локализации приложений относится утилита native2ascii , выполняющая преобразование текста в Unicode Latin-1.

В начало

В начало

Средства для защиты приложений

Утилиты, относящиеся к этой категории, используются для задания уровней защиты и создания приложений, который работают на удаленных узлах. К таким утилитам относятся:

keytool Средство для управления сертификатами
jarsigner Утилита для генерации и проверки цифровых подписей в JAR-файлах
policytool Графическое средство для управления файлами доступа
В начало

В начало

IDL-утилиты

Утилиты, относящиеся к этой категории, используются при создании приложений, использующих CORBA для доступа к базам данных. К таким утилитам относятся:

tnameserv Обеспечивает доступ к сервисам имен (naming service)
idltojava Создает java-файлы для интерфейсов OMG IDL и позволяет приложениям, написанным на языке Java , использовать функциональность CORBA
В начало

В начало

Набор Java-библиотек и базовых классов

Ядром Java 2 является библиотека классов Java Foundation Classes (JFC) версии 1.1, предназначенная для создания графическх интерфейсов Java-приложений. В ее состав входят собственно библиотека JFC версии 1.1 (которая была доступна для JDK 1.1 с февраля прошлого года) и следующие интерфейсы:

  • Abstract Windowing Toolkit (AWT)
  • Swing
  • Java 2D
  • Drag and Drop
  • Accessibility
Архитектура Java Foundation Classes показана на следующей диаграмме.
В начало

В начало

Abstract Windowing Toolkit

Abstract Windowing Toolkit позволяет создавать программы с графическими интерфейсами, независящими от конкретной платформы. Более того, программный интерфейс AWT намного проще и понятнее программных интерфейсов Windows, Motif или OS /2. В JDK 1.2 было добавлено много новых классов и интерфейсов, включая поддержку функций рисования, вывода на принтер, обработки изображений и поддержки Drag and Drop и Java 2D.

Многие из этих новых компонентов можно найти в галерее по адресу: http://java.sun.com/products/jfc/swingdoc-current/comp_gal.html. Также, можно посмотреть программу SwingSet, чтобы увидеть компоненты Swing в действии.

В начало

В начало

Swing

Компоненты Swing являются 100% Java-компонентами. Это означает, что они не зависят от конкретных реализаций интерфейсных элементов на той или иной платофрме. Это также означает, что эти компоненты доступны на всех платофрмах, где есть поддержка Java 2. Компоненты Swing реализованы как расширение AWT , но не используют компонентов AWT . На самом деле, многие традиционные компоненты AWT — кнопки, списки, диалоговые панели, были переделаны в компоненты Swing. Благодаря этому, компоненты AWT стали более доступными на различных платформах и теперь предоставляют дополнительные возможности, отсутствующие в некоторых графическх средах. На следующей диаграмме показано взаимодействие Swing и AWT.

Одно из наиболее интересных свойств библиотеки Swing — это возможность изменения внешнего вида компонентов и интерфейсов — Pluggable Look and F eel (PL&F). Архитектура PL&F позволяет настраивать внешний вид и поведение как одного компонента, так и группы компонентов. Также в состав Swing входит ряд предопределенных настроек — Metal L&F, Motif L&F, Windows L&F . Существуют настройки по умолчанию для Macintosh и других платформ.

Как мы отметили выше, компоненты Swing играют важную роль при создании графических интерфейсов программ. В следующей таблице приведены краткие описания этих компонентов.

В начало

В начало

Java 2D

С помощью Java 2D можно разработывать графические приложения. Этот программный интерфейс обеспечивает поддержку двух-мерной графики, обработку графических изображений, рендеринг, управление цветами и работу с устройствами печати. Интерфейс Java 2D состоит из модели, которая поддерживает отрисувку линий, графических изображений, преобразования цветов, составление графики. Модель является аппаратно-независимой. Интерфейс Java 2D реализован в пакетах java.awt и java.awt.image.

В начало

В начало

Drag and Drop

В Java 2 введена поддержка операций Drag and Drop, с помощью которых можно перетаскивать различные объекты. Интерфейс Drag and Drop в JDK 1.2 обеспечивает платформенно-независимую поддержку этих операций для Java-приложений, причем можно осуществлять перетаскивание объектов как между Java-программамиЮ так и между Java-программами и программами, «родными» для конкретной платформы. Интерфейс Drag and Drop реализован в пакете java.awt.dnd и поддерживается классами и интерфейсами других пакетов JFC.

В начало

В начало

Accessibility

Для пользователей с различными физическими недостатками в JDK 1.2 введен ряд интерфейсов, облегчающих создание сотоветствующих программных средств. Интерфейс Accessibility в JDK 1.2 реализован в пакете java.awt.accessibility.

В начало

В начало

Апплеты

При обзоре платформы Java нельзя не упомянуть апплеты — мини- приложения, загружаемые из сети и выполняемые вWeb- браузере. Так как аплеты загружаются из сети, они обычно содержат «непроверенный» код, что накладывает опрделенные требования к проверке их надежности. Апплеты сыграли большую роль в популяризации платформы Java и практически не изменились со времен Java 1.0. В Java 2 появился Swing-класс JApplet и новая, более гибкая модель защиты.

Базовый класс Applet и Swing-класс JApplet являются GUI-контейнерами, которые могут содержать другие GUI-компоненты и контейнеры. Но не эти свойства определяют основные характеристики апплетов. Наиболее важными здесь являются возможность работы в сети, динамическая загрузка и выполнение и развитые средства защиты.

В начало

В начало

JavaBeans

Компоненты JavaBeans .впервые появились в Java 1.1. В Java 2 реализованы некоторые расширения компонентной модели JavaBeans . Компонент JavaBeans — это Java-объект, интерфейс которого поддерживает некоторые соглашения. Так, компонентами можно управлять из средств разработки, из скриптовых языков и т.п. В некоторых случаях целые приложения могут быть динамически собраны из группы независимых, но взаимодейтсвующих друг с другом компонентов. Компоненты JavaBeans часто, но необязательно, являются GUI-компонентами. Все GUI-компоненты платформы Java следуют соглашениям компонентов JavaBeans и могут использоваться в контексте JavaBeans . Такими компонентами могут быть и простая кнопка, и сложный полнофункциональный текстовый процессор.

В Java 2 появилось понятие контекста компонента, — контейнера, который может содержать в себе компоненты и другие контейнеры. Такой контейнер может обеспечивать набор сервисов, например, возможность работы с устройством печати, для всех вложенных компонентов. Фактически, контекст контейнера является расширением модели апплетов — в платформе Java 2 реализована поддержка создания объектов, которые могут выступать и как компоненты, и как апплеты.

Более подробно о компонентах JavaBeans, средствах их создания и основных коммерческих компонентах мы поговорим в одной из следующих статей данного цикла.

В начало

В начало

Java Media Framework

Java Media Framework (JMF) — это стандартное расширение платформы Java 2. JMF задает библиотеку классов для работы со звуком и видео. В дополнение к возможностям воспроизведения аудио-данных и отображения видео-данных, закодированных в различных форматах, JMF включает средства для обработки, контроля и синхронизации потоков мультимедийных данных. Java Media Framework может работать как с файлами, хранимыми на локальных дисках, так и упакованными потоковыми данными, передаваемыми в реальном времени по сети.

Java Media Framework реализовано полностью на языке Java и может работать на любой платформе, поддерживающей язык Java . В дополнение к этому, существуют платформенно-зависимые расширения в коде для той или иной платформы, с помощью которых можно существенно повысить производительность создаваемых приложений и обеспечить поддержку специфичных для данной платформы форматов данных.

В следующих версиях JMF будут реализованы средства записи мультимедийных данных и поддержки конференций.

В начало

В начало

Поддержка звука

В первых двух версиях Java (1.0 и 1.1) были лишь рудиментарные функции для поддержки звука — можно было воспроизводить только звук, закодированный в формате AU фирмы Sun. Соответствующие интерфейсы были доступны только для апплетов. Платформа Java 2 содержит новое ядро для воспроизведения звуковых файлов в натболее популярных форматах, а программные интерфейсы могут использоваться в любом Java-коде, не только в апплетах, как это было раньше.

Для поддержки звука в состав Java 2 включен интерфейс Java Sound , обеспечивающий полный контроль над аудио-данными.

В начало

В начало

Разработка корпоративных приложений

Большинство новинок в платформе Java 2 — это новинки в графических интерфейсах и поддержке графических функций. Но наиболее важными, со стратегической точки зрения, несомненно, являются программные интерфейсы Java Enterprise. Эти интерфейсы позволяют использовать Java для создания корпоративных приложений, которые обладают средствами масштабирования, могут работать в сетевых средах и обладают поддержкой работы с уже существующими приложениями.

Некоторые из этих интерфейсов существовали в Java 1.1, часть из них являются новыми для Java 2. Ряд интерфейсов является базовым для платформы Java 2, остальные — это дополнения и расширения. Тем не менее именно платформа Java 2.является первой, где полностью реализованы интерфейсы Java Enterprise, и которая служит в качестве основы для создания корпоративных приложений.

Ниже мы кратко рассмотрим основные интерфейсы Java Enterprise (более подробно мы погворим об этих интерфейсах в одной из следующих статей данного цикла). К ним относятся:

  • JDBC — доступ к базам данных
  • RMI — поддержка распределенных объектов
  • Распределенные объекты и CORBA
  • JNDI — Сервисы имен и каталогов
  • JavaMail — электронная почта
  • Enterprise JavaBeans
  • Сервлеты
В начало

В начало

Доступ к базам данных

Интерфейс Java Database Connectivity (JDBC) позволяет Java-программам посылать SQL-запросы и обновлять данные на серверах баз данных, а также обрабатывать полученные с сервера результаты. JDBC также позволяет получать метаинформацию о базе данных и ее таблицах с сервера баз данных. Архитектура JDBC основывается на классе Driver , который «скрывает» все детали общения с конкретным сервером баз данных. Каждый конкретный сервер требует наличия соответствующего класса Driver , с которым взаимодействуют Java-программы. Большинство производителей баз данных поставляют JDBC-драйверы со своими продуктами. Помимо этого, существуют специальные драйверы для взаимодействия с базами через соответствующие ODBC-драйверы. На следующей диаграмме показаны два возможных варианта создания JDBC-приложений — с использованием только JDBC-драйверов и с использованием JDBC/ODBC-драйверов.

Интерфейс JDBC реализован в пакете java.sql , который впервые появился в Java 1.1. В платформе Java 2 появился ряд новых классов, реализующих дополнительную функциональность. Также в Java 2 включен пакет javax.sql , позволяющий, например, рассматривать результаты запроса к базам данных как JavaBeans , выполнять пулинг связей с базами и получать информацию о связях с базами через сервисы имен.

Интерфейс JDBC является простым и хорошо продуманным. Программисты, знакомые с SQL и основами программного взаимодействия с базами данных, смогут легко воспользоваться функциями JDBC в Java-программах.

В начало

В начало

Поддержка распределенных объектов

Распределенные объекты обеспечивают мощную модель для создания объектно-ориентированных сетевых приложений, интерес к которым в последние годы неуклонно растет. В данной модели клиентская часть должна иметь возможность вызывать методы объектов, расположенных на удаленных серверах так, как если бы эти объекты располагались локально. Данная модель может быть реализована несколькими способами. Одним из них является Java Remote Method Invocation (RMI). Соответствующие програмные интерфейсы реализованы в пакете java.rmi , который впервые появился в Java 1.1 и был расширен в Java 2.

В начало

В начало

Распределенные объекты и CORBA

Java Remote Method Invocation — это решение для создания распределенных систем, которое работает для клиентских и серверных приложений, написанных на языке Java . Но оно не подходит для гетерогенных сред, где клиенты и серверы написаны на различных языках. Для таких сред в платформе Java 2 реализована поддержка CORBA.

CORBA (Common Object Request Broker Architecture) — это стандарт, созданный Object Management Group (OMG). Данный стандарт реализован как базовая составляющая платформы Java 2 в пакете org.omg.CORBA и других подпакетах. Реализация включает Object Request Broker (ORB), который Java-приложения могут использовать для общения с другими брокерами и другими CORBA-объектами.

Интерфейсы к удаленным CORBA-объектам являются независимыми от языка и платформы и описываются на языке описания интерфейсов — Interface Description Language (IDL). В состав Java Development Kit входит компилятор IDL , который преобразует интерфейсы, описанные на языке Interface Description Language в специальные Java-классы, необходимые для реализации IDL-интерфейсов на Java или для связи с удаленными реализациями интерфейсов из Java-кода.

В начало

В начало

Сервисы имен и каталогов

Интерфейсы Java Naming and Directory Interface (JNDI) представляют собой независимые от протоколов интерфейсы к сетевым сервисам имен и каталогов. Эти интерфейсы реализованы в пакете javax.jndi , который является стандартным расширением платформы Java 2.

Интерфейсы JNDI не являются специфичными для каких-то протоколов поддержки сервисов имен и каталогов. Вместо этого они представляют собой базовые интерфейсы, способные работатть с любыми серверами. Для поддержки какого-то конкретного протокола требуется наличие специального провайдера. Для большинства провайдеров таких сервисов — LDAP, DNS или NIS реализованы соответствующие программные средства.

В начало

В начало

Электронная почта

Интерфейс JavaMail представляет собой независящий от протоколов интерфейс к сервисам электронной почты. Он поддерживает возможность отсылки и получения электронной почты, а также такие функции, как поиск. Интерфейс JavaMail реализован в пакете javax.mail и подпакетах и является стандартным расширением платформы Java 2.

Как и JNDI, JavaMail не связан с каким-то конкретным протоколом для получения и отсылки электронной почты. JavaMail — это набор базовых функций, способных работать с любым протоколом. Реализация конкретного протокола — SMTP, IMAP или POP3 — требует наличия соответствующего провайдера, который входит в комплект поставки.

В начало

В начало

Enterprise JavaBeans

Enterprise JavaBeans — это серверный аналог JavaBeans. Enterprise JavaBeans (EJB) представляет собой компонентную модель для реализации бизнес- логики и базнес- данных. Программная модель с «тонким» клиентом предполагает вынос бизнес-логики с клиентской части на сервер или промежуточный уровень (middle tier) и позволяет создавать более гибкие корпоративные приложения. Но при этом, реализация бизнес-логики связана с необходимостью поддержки кода, который бы обрабатывал транзакции, взаимодействовал бы с сетью и обеспечивал бы средства защиты информации.

Модель EJB отделяет бизнес-логику от низкоуровневых функций, позволяя разработчикам не заботиться о том, как в том или ином случае будут реализованы стандартные функции, например, для передачи данных или обработки транзакций.

Пакеты javax.ejb и javax.ejb.deployment являются стандартными расширениями платформы Java 2 и содержат классы, необходимые для создания и внедрения EJB . Архитектура EJB также взаимодействует с интерфейсами JNDI и другим стандартным расширением — Java Transaction Services ( JTS).

В начало

В начало

Сервлеты

Сервлет — это Java-код, выполняемый на сервере, и обеспеичвающий какие-то сервисы для клиента. Название «сервлет» схоже с названием «апплет» — сервлет является серверным апплетом. Интерфейс Java Servlet предоставляет базовый механизм для расширения функциональности любого сервлета, использующего запросы и ответы на базе любого протокола.

В настоящее время сервлеты используются, в основном на Web-серверах. Таким образом сервлеты можно назвать Java-аналогом CGI-программ. Сервлеты вполне конкурентно-спрособны с такими технологиями, как Active Server Pages фирмы Microsoft или Cold Fusion фирмы Allaire . Преимуществом использования сервлетов является то, что они являются независимыми от платформы и сохраняются в памяти псле загрузки (в отличие от CGI-программ). Помимо этого сервлеты имеют полный доступ к платформе Java и могут выполнять такие функции, как связь с базами данных.

Сервлеты являются стандартным расширением платформы Java 2 и реализованы в пакетах javax.servlet и javax.servlet.http . Пакет javax.servlet задает классы для обработки клиентских запросов и серверных ответов. Пакет javax.servlet.http обеспечивает поддержку протокола HTTP , включая обработку запросов от нескольких клиентов в рамках обной клиентской сессии.

В начало

В начало

Это еще не все

Как мы увидели выше, платформа Java 2 предоставляет в распоряжение разработчиков большой набор разнообразных программных интерфейсов, с помощью которых возможно реализовать практически любые приложения. Помимо этого, фирма Sun работает над различными расширениями и дополнениями к платформе Java 2, которые со временем могут стать стандартными расширениями этой платформы. В следующей таблице перечислены наиболее важные расширения, работа над которыми еще ведется.

Интерфейс Описание
Advanced Imaging API Обеспечивает высокопроизводительные средства для обработки изображений, включая поддержку работы с изображениями большого размера, фрагментарно хранимыми на дисках.
Java Speech Обеспечивает поддеркуж синтеза речи и разпознавание голоса.
Java Telephony Представляет собой интерфейс для создания компьютерных приложений для работы с телефонией.
Project X Кодовое название расширений для поддержки языка XML
Java Communications API Позволяет Java-приложениям использовать последовательные и параллельные порты компьютера
Jini Набор пакетов для обеспечения сетевых функций «plug-and-play» для компьютеров, периферийных устройств и различных элемктронных приспособлений
Java Message Service Предствляет собой интерфейс для асинхронного обмена сообщениями.
Java Transaction Service/Java Transaction API Эти программные интерфейсы задают средства управления транзакциями и их обработки. Реализуют стандарты X/Open XA и OMG OTS для управления транзакциями
Java Electronic Commerce Framework Представляет собой набор классов для создания приложений электронной коммерции, используя метафору «бумажника» на клиентском компьютере
Java Management API Задает набор интерфейсов для централизованного управления динамическими распределенными Java-приложениями и средами

В следующем номере мы начнем знакомство со средствами создания Java-приложений и аплетов, выпускаемыми различными фирмами.

КомпьютерПресс 4'1999

1999 1 2 3 4 5 6 7 8 9 10 11 12
2000 1 2 3 4 5 6 7 8 9 10 11 12
2001 1 2 3 4 5 6 7 8 9 10 11 12
2002 1 2 3 4 5 6 7 8 9 10 11 12
2003 1 2 3 4 5 6 7 8 9 10 11 12
2004 1 2 3 4 5 6 7 8 9 10 11 12
2005 1 2 3 4 5 6 7 8 9 10 11 12
2006 1 2 3 4 5 6 7 8 9 10 11 12
2007 1 2 3 4 5 6 7 8 9 10 11 12
2008 1 2 3 4 5 6 7 8 9 10 11 12
2009 1 2 3 4 5 6 7 8 9 10 11 12
2010 1 2 3 4 5 6 7 8 9 10 11 12
2011 1 2 3 4 5 6 7 8 9 10 11 12
2012 1 2 3 4 5 6 7 8 9 10 11 12
2013 1 2 3 4 5 6 7 8 9 10 11 12
Популярные статьи
КомпьютерПресс использует