Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
книги хакеры / Питер_Гудлиф_Ремесло_программиста_Практика_написания_хорошего_кода.pdf
Скачиваний:
16
Добавлен:
19.04.2024
Размер:
9.23 Mб
Скачать

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

Какойm

инструмент необходим?

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

167Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

w

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

.c

 

 

.

 

 

 

 

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

руют быстрее других. Только вы успели установить очередной widgeti% zer, как авторы выпустили новую версию с длинной красной полосой сбоку.

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

Новые версии могут содержать новые ошибки и продаваться по но% вым, более высоким ценам. Обновляйте продукт, только если он сулит существенные улучшения и показал свою стабильность. Проверьте сначала новый инструмент на своем старом коде, чтобы убедиться в его корректной работе.

Следите за выпуском новейших версий своего инструмента, но проявляйте осторожность при обновлении.

Какой инструмент необходим?

Ассортимент инструментов для разработки программ ошеломляет. Потребности, которые часто возникают, известны, и за годы развития набралось много инструментов, удовлетворяющих любые прихоти. Ес% ли какая%то задача возникает многократно, можете быть уверены, что кто%то уже написал инструментарий для ее решения.

Точный состав вашего инструментального набора зависит от рода ва% шей работы. Инструменты для встроенных платформ обычно уступа% ют в богатстве возможностей инструментам для настольных приложе% ний. Ниже мы рассмотрим стандартные компоненты. Одни из них оче% видны в большей степени, другие – в меньшей.

Мы рассмотрим каждый класс инструментов в отдельности, но нужно помнить, что современные IDE объединяют частные программы под единым удобным интерфейсом. Несмотря на это удобство, важно разо% браться в самостоятельной роли каждого инструмента, поскольку

вы сможете более эффективно использовать отдельные функции;

вы узнаете, каких полезных функций нет в вашей IDE.

Обычно IDE имеют модульную структуру, что позволяет заменять от% дельные компоненты более эффективными или добавлять возможности, отсутствующие в оригинальной версии. Изучайте существующие раз% новидности инструментов и совершенствуйте возможности своей IDE.

Средства редактирования исходного кода

Гончару материалом служит глина, скульптору – камень, программи% сту – код. Это основной материал, с которым мы работаем, поэтому

 

 

 

 

hang

e

 

 

 

 

 

 

C

 

E

 

 

 

X

 

 

 

 

 

-

 

 

 

 

 

d

 

F

 

 

 

 

 

 

t

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

to

 

 

 

 

w Click

 

 

 

168m

 

 

 

 

w

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

.

 

 

 

 

 

.c

 

 

p

 

 

 

 

g

 

 

 

 

df

 

 

n

e

 

 

 

 

-xcha

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

Глава 7. Инструментарий программистаClick

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

w

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

.c

 

 

.

 

 

 

 

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

необходимо выбрать лучшие инструменты для написания, редактиро% вания и изучения исходного кода.

Редактор исходного кода

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

Выбор редактора кода имеет решающее значение; он оказывает огромное влияние на то, как вы будете писать код.

Выбор Единственного настоящего редактора исходного кода – это ста% рый спор, который мы не станем поднимать вновь. Вам должно быть удобно работать в редакторе, и он должен отвечать всем вашим требо% ваниям. Если в вашей IDE есть встроенный редактор, это не значит, что он окажется для вас лучшим. С другой стороны, то, что он встроен, может стать чрезвычайным удобством. Я предъявляю к редактору ис% ходного текста как минимум следующие требования:

Полная подсветка синтаксиса (при поддержке нескольких языков, т. к. я работаю со многими языками)

Простая проверка синтаксиса (например, подсветка непарных ско% бок)

Хорошие средства инкрементального поиска (интерактивное окно, осуществляющее поиск одновременно с набором с клавиатуры)

Запись действий с клавиатурой в макросы

Широкие возможности настройки

Работа на всех платформах, которыми я пользуюсь

Ваши требования и выбор редактора могут отличаться от моих, но мне кажется, что я привел разумный список самых важных возможно% стей. При этом стоит потратить некоторое время, чтобы научиться наиболее эффективно пользоваться всеми этими возможностями. Ре% зультатом будет рост производительности труда.

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

Vim и Emacs – печально известные редакторы из мира UNIX, которые теперь доступны практически на любой платформе, чуть ли не на элект% рических тостерах. Они весьма отличаются от редакторов, включае% мых в IDE.

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

Какойm

инструмент необходим?

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

169Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

w

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

.c

 

 

.

 

 

 

 

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Средства обработки исходного текста

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

Следующие команды UNIX предоставляют мощный механизм для изучения и модификации исходного кода:

diff

Сравнивает два файла и выявляет различия между ними. Базовая версия diff выводит результат на консоль, но существуют более изо% щренные графические версии. Есть даже редакторы, позволяющие работать со сравниваемыми файлами, показывая их рядом и обнов% ляя различия по мере редактирования текста. Совсем необычные варианты diff сравнивают одновременно три файла.

sed

Сокращение от stream editor – потоковый редактор. sed читает файлы построчно и применяет к ним заданное правило преобразо% вания. С помощью sed можно менять порядок элементов, выпол% нять глобальный поиск и замену или вставлять в строки шаблоны.

awk

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

grep

Ищет в файле символы, соответствующие шаблону. Шаблоны опи% сываются с помощью регулярных выражений – особого мини%языка с символами%заместителями и гибкими критериями соответствия.

find/locate

Это средства поиска файлов в файловой системе. Поиск можно вес% ти по имени, дате и ряду других критериев.

Это лишь вершина айсберга; существует множество других инстру% ментов. Например, wc подсчитывает символы/слова. Другие ценные утилиты: sort, paste, join и cut.

Средства навигации в исходном коде

В действительно крупном проекте код можно уподобить городу. Даже те, кто планировал его, не знают всех улиц на окраинах. Немногие таксисты знают, как лучше всего добраться в нужное место. Обычно жители хорошо знакомы лишь со своими ближайшими окрестностя%

 

 

 

 

hang

e

 

 

 

 

 

 

C

 

E

 

 

 

X

 

 

 

 

 

-

 

 

 

 

 

d

 

F

 

 

 

 

 

 

t

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

to

 

 

 

 

w Click

 

 

 

170m

 

 

 

 

w

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

.

 

 

 

 

 

.c

 

 

p

 

 

 

 

g

 

 

 

 

df

 

 

n

e

 

 

 

 

-xcha

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

Глава 7. Инструментарий программистаClick

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

w

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

.c

 

 

.

 

 

 

 

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

ми. Туристы теряют всякую ориентировку, как только выйдут из ав% тобуса.

Существует разновидность инструментов, с помощью которых легче разобраться в коде, составить его схемы, выполнять несложный поиск, навигацию и делать перекрестные ссылки. Некоторые инструменты строят графические деревья вызовов, по которым можно следить, как передается управление в системе. Они могут создавать графические схемы или объединяться с редактором, чтобы обеспечивать автозавер% шение, подсказывать сигнатуру функции и т. п. Это неоценимый ин% струмент для работы с большим объемом кода или первого знакомства с уже устоявшимся проектом.

Хорошим примером бесплатных инструментов такого рода служат LXR, Doxygen и почтенный ctags.

Управление версиями

Мы не станем здесь распространяться на тему этих инструментов, по% скольку о них рассказывается в разделе «Управление версиями исход% ного кода» на стр. 449. Скажем лишь одно: если вы не будете ими пользоваться, вам следует отрубить руки.

Генерирование исходного кода

Есть ряд средств для автоматического генерирования исходного кода. Некоторые из них хороши, другие приводят меня в ужас.

Один из примеров – это yacc, генератор синтаксических анализаторов LALR(1).1 Нужно определить правила входной грамматики, а затем с помощью этого инструмента генерировать программы, которые мо% гут проводить синтаксический анализ корректных текстов, соответст% вующих этим правилам. В итоге получается анализатор на C с ловуш% ками, куда можно добавить свои функции для анализа объектов. Ана% логичные задачи решает Bison.

Есть класс инструментов, генерирующих код, которые применяются при разработке интерфейса пользователя. Они выдают рабочий сер% верный код. Особенно часто их применяют со сложными инструмента% риями GUI типа MFC. Если для библиотеки требуется инструмент, ко% торый выполняет столько тяжелой работы, из этого можно сделать вывод, что библиотека чрезмерно сложна (или порочна в своей осно% ве). Будьте осторожны!

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

1Загадочный технический (и неинтересный) способ выражения достаточно

сложной грамматики.