Правила программирования на С и С++. Главы 1-6 - Пробел - один из наиболее эффективных комментариев

ОГЛАВЛЕНИЕ

 

39. Пробел - один из наиболее эффективных комментариев.

Это кажется мелочью, но это может чрезвычайно улучшить читаемость вашей программы. Обратите внимание, как используются пробелы в этой книге в качестве организующего средства, и вы поймете, как использовать их в своей собственной программе. Пустые строки (или отступ в первой строке) зрительно разделяют абзацы. Пробел следует за точкой, но не должен ей предшествовать, потому что точка завершает что-либо. Вы получили идею. А вот правила:

  • Разбивайте текст программы на логические куски (т.е. абзацы), где каждый кусок выполняет одну операцию. Окружите эти куски или пустыми строками, или строками с фигурными скобками.
  • За знаком препинания всегда должен идти пробел.
  • Операторы являются сокращениями слов. Когда вы видите "+", то говорите "плюс". Подобно любому сокращению, вы должны окружать идентификатор пробелами. (Например: a + b читается "a плюс b", a+b читается "aплюсb").
  • Исключение составляют унарные операторы, которые рассматриваются как словарные префиксы или суффиксы (*p,a--,f(arg,arg), и т.д.).
  • . или -> в С/С++ являются эквивалентом символа подчеркивания. До и после них пробелов быть не должно: p->msg(), obj.msg().
Вот пример того, что может произойти, когда вы что-нибудь упаковываете слишком плотно. Рассмотрим: int *p;

y=(x/*p++);

f(int /* place-holder */);

Если вы удалите комментарии, то получите: int *p;

y=(x

);Сочетание /* в выражении y=(x/*p++) расценивается как символ начала комментария, который заканчивается сочетанием */ в вызове функции f(). (Такой случай действительно со мной произошел, и мне потребовался целый день, чтобы в нем разобраться. Естественно, компилятор не давал сообщений об ошибках, потому что здесь все синтаксически правильно).

Еще замечание по данному поводу. Мне часто приходилось позднее видеть объявления подобные следующему:

int* x;Проблема состоит в том, что: int* x, y;не объявляет два указателя, как подсказывает распределение пробелов. Здесь мы имеем на самом деле еще одну проблему из рода "я могу на любом языке программирования писать как на ФОРТРАНЕ". Было бы прекрасно, если бы С работал также, как подсказывает предыдущее форматирование, но это не так. После правильного форматирования int *x, y;

становится совершенно ясно, что x - указатель, а y - нет.