Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
ТЕХНОЛОГИИ ДОСТ... 63625
Имитационное мо... 58648
Реклама
Сейчас на сайте
Гостей: 6
На сайте нет зарегистрированных пользователей

Пользователей: 13,095
новичок: staros
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Метод конечных разностей для интерполяции/экстраполяции на Delphi
Моделирование системы управления качеством производственного процесса на...
Медиа плейер на Delphi + Пояснительная записка

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
15.6. Дополнительная литература
Большая часть книг, упомянутых в разделе 8.8, содержит информацию об эффективных алгоритмах и удобных структурах данных, применяемых для представления и обработки строк.
Эпилог к первому изданию
Интервью с автором показалось мне тогда наилучшим завершением первого издания книги. Оно все еще не потеряло своей актуальности, так что я вновь привожу его здесь.
Вопрос: Спасибо, что согласились ответишь намой вопросы (в дальнейшем вопросы выделены курсивом).
Ответ: Не за что: мое время — это и ваше время.
Все главы этой книги уже были напечатаны в качестве статей в Communications of the ACM. Почему вы решили собрать их вместе и выпустить книгу?
Существует несколько причин. Я исправил десятки ошибок, сделал сотни небольших улучшений и добавил несколько новых разделов. В книге на 50% больше задач, решений и иллюстраций. Кроме того, удобнее работать с книгой, чем со статьями, разбросанными по десятку журналов. Главная же причина заключается в том, что предметы обсуждения этих глав лучше проявляются, когда они собраны вместе. Целое оказывается большим, чем сумма его частей.
И какие же это предметы?
Самое главное заключается в том, что углубиться в размышления о программе может быть интересно и полезно. Наша работа — это нечто большее, чем просто систематическая разработка программы по техническим требованиям. Если эта книга поможет хотя бы одному программисту, утратившему иллюзии, снова полюбить свою работу, я буду считать цель достигнутой.
Какой-то сбивчивый ответ. Есть ли какие-то технические нити, связывающие главы воедино?
Часть вторая посвящена производительности, но производительность является общим вопросом всех глав. В нескольких главах интенсивно используются методы верификации программ. В приложении 1 приведен каталог алгоритмов, используемых в книге.
Судя по всему, большая часть глав посвящена процессу разработки. Можете ли вы дать какой-то общий совет на эту тему?
206 Эпилог к первому изданию
Я рад, что вы спросили. Я случайно подготовил список советов перед этим интервью. Вот десять предложений для программистов.
1. Решайте правильную задачу.
2. Исследуйте пространство решений.
3. Изучите данные.
4. Делайте предварительные оценки.
5. Учитывайте симметрию задачи.
6. Применяйте компоненты.
7. Создавайте прототипы.
8. Идите на необходимые компромиссы.
9. Не усложняйте сверх необходимого.
10. Стремитесь к изящности решения.
Эти советы мы приводим в контексте задач программирования, но они применимы к любой инженерной деятельности.
Здесь возникает вопрос, который давно меня беспокоил: легко упрощать маленькие программы в книге, но подходят ли эти методы для больших программных систем?
У меня есть три ответа: да, нет и возможно. Да, они подходят. В разделе 3.4 (первого издания) описан большой проект, который был упрощен до «всего лишь» 80 человеко-лет. Настолько же верен и ответ «нет»: если правильно упрощать, в большой системе просто не будет необходимости, поэтому к ней не придется применять эти методы. Хотя оба ответа достойны, истина, как всегда, лежит где-то посередине, и вот отсюда возникает ответ «возможно». Некоторые программы не могут не быть большими, и некоторые методы из этой книги могут к ним подойти. Операционная система Unix — это хороший пример мощного целого, построенного из простых и изящных частей.
Вот вы снова говорите о системе, созданной в Bell Labs. Не является ли эта книга слишком улс предвзятой?
Ну, возможно, немного. Я обращался к материалу из собственного опыта, и поэтому примеры относятся к тому, что меня окружало. Большая часть материала этих глав была предложена моими коллегами, и они заслужили похвалу (или упреки). Я многому научился от исследователей и разработчиков в Bell Labs. Мы работаем в атмосфере сотрудничества, стимулирующей взаимодействие между исследованиями и разработками. Поэтому то, что вы называете предвзятостью, на самом деле является проявлением восторженного отношения к компании.
Давайте спустимся па землю. Чего в этой книге не хватает?
Я надеялся включить в нее пример большой системы, состоящей из множества программ, по не смог найти такую систему, которую можно было бы описать на десяти страницах (типичный размер одной статьи). Я хотел бы добавить в нее несколько глав на тему «информатика для программистов» (наподобие глав о верификации программ или разработке алгоритмов) и «инженерные методы вычислений» (пример: предварительные оценки в главе 7).
Если вы так увлекаетесь «наукой» и «инженерией», почему в этих главах так мало теорем и таблиц и так много рассказов?
Очень просто: людям, которые берут интервью сами у себя, не следует критиковать стиль.
Опубликовал vovan666 April 17 2013 04:05:02 · 0 Комментариев · 2542 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
C++ : библиотека ...
Базы данных в Инт...
Разработка клиент...
Современное проек...
Мод "проверочный ...
Работа с картотеками
Последние загруж...
GamesBase 3.0
Программирование ...
Моделирование дви...
PHP 5 для "чайников"
Работа с базами д...
AntiRus
Java 2 - Эффектив...
FormShape [Исходн...
Конвертирование и...
Разработка распре...
Progressbar
mp3tag
Пример создания W...

Топ загрузок
Приложение Клие... 100490
Delphi 7 Enterp... 88218
Converter AMR<-... 20084
GPSS World Stud... 13854
Borland C++Buil... 12155
Borland Delphi ... 8712
Turbo Pascal fo... 7058
Visual Studio 2... 5007
Калькулятор [Ис... 4937
FreeSMS v1.3.1 3547
Случайные статьи
Спил деревьев
Глава 8. Базовы...
Создание таблиц Ex...
Получающий информа...
Программирование г...
Какие бонусные про...
Интерпретация данн...
Сверточные (рекурр...
Генерирование сигн...
Большинство програ...
Вывод команды show...
Документы СС/РР
Рекурсивное вычисл...
Помимо вызова акти...
Запоминание пути в...
Определение шаблон...
Подводные камни вн...
Физическая установ...
Простая блокировка...
Определение виртуа...
Изменение направле...
Связь комментариев...
STREAMS и ядро сис...
SRV, зарегистриров...
Стеки в Delphi
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?