Правила программирования на Си и Си++

       

Не старайтесь порадовать lint


Lint является программой проверки синтаксиса для языка Си. (Также имеется версия для Си++ в среде MS-DOS/Windows. Она выпускается фирмой Gimple Software). Хотя эти программы неоценимы при использовании время от времени, они выводят такую кучу сообщений об ошибках и предупреждений, что текст вашей программы будет почти невозможно прочитать, если вы попробуете избавиться от всех них. Оказывается, нужно избегать кода, подобного следующему:

(void ) printf("...");

Тут вообще нет ничего неверного в присваивании в цикле:

while( p = f() )

    g(p);

даже если новичок в программировании может воспользоваться символом =

вместо ==. (Проблемы новичков не должны приниматься во внимание, когда вы обсуждаете рекомендуемый стиль для опытных профессионалов. Это похоже на принятие закона, который требует, чтобы все велосипеды оснащались боковыми колесиками, потому что двухлетним малышам без них тяжело кататься).

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

вместо ==:

#define MAX 100

// ...

if ( MAX == x )

// ...

В этой идее есть достоинства, но я нахожу, что такой код труднее читается.



Содержание раздела