Брюс Эккель - Философия Java3
- Название:Философия Java3
- Автор:
- Жанр:
- Издательство:неизвестно
- Год:неизвестен
- ISBN:нет данных
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Брюс Эккель - Философия Java3 краткое содержание
Философия Java3 - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Основные исключения...........................310
Перехват исключений...........................312
Создание собственных исключений.....................314
Спецификации исключений.........................319
Перехват произвольных исключений....................320
Стандартные исключения Java.......................328
Завершение с помощью finally.......................330
Использование finally с return........................334
Ограничения при использовании исключений...............336
Конструкторы...............................339
Идентификация исключений........................343
Альтернативные решения.........................344
Резюме...................................351
Глава 13. Информация о типах..................352
Необходимость в динамическом определении типов (RTTI).........352
Регистрация фабрик............................372
Рефлексия: динамическая информация о классе..............376
Динамические посредники.........................380
Объекты с неопределенным состоянием..................384
Интерфейсы и информация о типах....................390
Резюме...................................394
Глава 14. Параметризация.....................397
Простая параметризация..........................398
Параметризованные интерфейсы......................404
Параметризованные методы........................407
Построение сложных моделей.......................419
Ограничения................................437
Метасимволы................................440
Резюме...................................452
Глава 15. Массивы........................454
Особенности массивов...........................454
Массив как объект.............................456
Возврат массива..............................458
Многомерные массивы...........................460
Массивы и параметризация.........................463
Создание тестовых данных.........................465
Создание массивов с использованием генераторов.............470
Вспомогательный инструментарий Arrays..................474
Резюме...................................482
Глава 16. Система ввода/вывода Java...............483
Класс File..................................484
Ввод и вывод................................489
Добавление атрибутов и интерфейсов...................491
Классы Reader и Writer...........................494
RandomAccessFile: сам по себе.......................497
Типичное использование потоков ввода/вывода..............498
Средства чтения и записи файлов.....................505
Стандартный ввод/вывод..........................507
Новый ввод/вывод (nio)..........................510
Сжатие данных...............................531
Сериализация объектов..........................536
Предпочтения...............................553
Резюме...................................555
Глава 17. Параллельное выполнение...............557
Класс Thread................................559
Исполнители................................561
Совместное использование ресурсов....................578
Взаимодействие между потоками......................598
Взаимная блокировка............................602
Новые библиотечные компоненты.....................607
CountDownLatch..............................607
CyclicBarrier.................................609
DelayQueue.................................611
PriorityBlockingQueue............................614
Семафоры.................................619
Exchanger.................................623
Моделирование...............................624
Резюме...................................629
Алфавитный указатель......................631
Посвящается Дон
Введение в объекты
Мы препарируем природу, преобразуем ее в концепции и приписываем им смысл так, как мы это делаем во многом, потому что все мы являемся участниками соглашения, которое имеет силу в обществе, связанном речью, и которое закреплено в структуре языка... Мы не можем общаться вовсе, кроме как согласившись с установленными этим соглашением организацией и классификацией данных.
Бенджамин Ли Ворф (1897-1941)
Возникновением компьютерной революции мы обязаны машине. Поэтому наши языки программирования стараются быть ближе к этой машине.
Но в то же время компьютеры не столько механизмы, сколько средства усиления мысли («велосипеды для ума», как любит говорить Стив Джобе), и еще одно средство самовыражения. В результате инструменты программирования все меньше склоняются к машинам и все больше тяготеют к нашим умам, также как и к другим формам выражения человеческих устремлений, как-то: литература, живопись, скульптура, анимация и кинематограф. Объектно-ориентиро-ванное программирование (ООП) — часть превращения компьютера в средство самовыражения.
Эта глава познакомит вас с основами ООП, включая рассмотрение основных методов разработки программ. Она, и книга вообще, подразумевает наличие у вас опыта программирования на процедурном языке, не обязательно С. Если вам покажется, что перед прочтением этой книги вам не хватает познаний в программировании и синтаксисе С, воспользуйтесь мультимедийным семинаром Thinking in С, который можно загрузить с сайта www.MindView.net.
Настоящая глава содержит подготовительный и дополнительный материалы. Многие читатели предпочитают сначала представить себе общую картину, а уже потом разбираться в тонкостях ООП. Поэтому многие идеи в данной главе служат тому, чтобы дать вам цельное представление об ООП. Однако многие люди не воспринимают общей идеи до тех пор, пока не увидят конкретно, как все работает; такие люди нередко вязнут в общих словах, не имея перед собой примеров. Если вы принадлежите к последним и горите желанием приступить к основам языка, можете сразу перейти к следующей главе — пропуск этой не будет препятствием для написания программ или изучения языка. И все же чуть позже вам стоит вернуться к этой главе, чтобы расширить свой кругозор и понять, почему так важны объекты и какое место они занимают при проектировании программ.
Развитие абстракции
Все языки программирования построены на абстракции. Возможно, трудность решаемых задач напрямую зависит от типа и качества абстракции. Под словом «тип» я имею в виду: «Что конкретно мы абстрагируем?» Язык ассемблера есть небольшая абстракция от компьютера, на базе которого он работает. Многие так называемые «командные» языки, созданные вслед за ним (такие,* как Fortran, BASIC и С), представляли собой абстракции следующего уровня. Эти языки обладали значительным преимуществом по сравнению с ассемблером, но их основная абстракция по-прежнему заставляет думать вас о структуре компьютера, а не о решаемой задаче. Программист должен установить связь между моделью машины (в «пространстве решения», которое представляет место, где реализуется решение, — например, компьютер) и моделью задачи, которую и нужно решать (в «пространстве задачи», которое является местом существования задачи — например, прикладной областью). Для установления связи требуются усилия, оторванные от собственно языка программирования; в результате появляются программы, которые трудно писать и тяжело поддерживать. Мало того, это еще создало целую отрасль «методологий программирования».
Альтернативой моделированию машины является моделирование решаемой задачи. Ранние языки, подобные LISP и APL, выбирали особый подход к моделированию окружающего мира («Все задачи решаются списками» или «Алгоритмы решают все» соответственно). PROLOG трактует все проблемы как цепочки решений. Были созданы языки для программирования, основанного на системе ограничений, и специальные языки, в которых программирование осуществлялось посредством манипуляций с графическими конструкциями (область применения последних оказалась слишком узкой). Каждый из этих подходов хорош в определенной области решаемых задач, но стоит выйти из этой сферы, как использовать их становится затруднительно.
Читать дальшеИнтервал:
Закладка: