Разделы кода не должны быть то, " закомментировал"
Примечание
Используйте Bug Finder вместо Code Prover для проверки правил кодирования. Поддержка кодирования правил, регистрируясь в Code Prover будет удалена в будущем релизе. См. Вопросы совместимости.
Разделы кода не должны быть то, " закомментировал".
C комментарии заключен в /* */
не поддерживайте вложение. Комментарий, начинающийся с /*
концы в первом */
даже когда */
предназначается как конец более позднего вложенного комментария. Если раздел кода, который комментируется уже, содержит комментарии, можно столкнуться с ошибками компиляции (или по крайней мере закоментировать меньше кода, чем вы предназначаете).
Комментирование кода не является хорошей практикой. Закоментированный код может остаться из синхронизации с окружающим кодом, не вызывая ошибки компиляции. Позже, если вы не комментируете код, можно столкнуться с неожиданными проблемами.
Используйте комментарии только, чтобы объяснить аспекты кода, которые не очевидны из самого кода.
Средство проверки использует внутреннюю эвристику, чтобы обнаружить закоментированный код. Например, символы, такие как #
, ;
, {
или }
укажите на комментарии, которые могут потенциально содержать код. Эти комментарии затем оценены против других метрик, чтобы определить вероятность кода, подменяющего комментарием. Например, несколько последовательных слов без промежуточного символа уменьшают эту вероятность.
Средство проверки не отмечает следующие комментарии, даже если они содержат код:
Доксиджен комментирует начало с /**
, /*!
, ///
или //!
.
Комментарии, которые повторяют тот же символ больше чем пять раз, например, символ =
здесь:
/* ===================================== * A comment * =====================================*/
Комментарии к первой линии файла.
Комментарии, которые смешивают стиль C (/* */
) и стиль C++ (//
).
Комментарии, которые содержат один или несколько @
символ. Если @
символ помещается во вложенный комментарий, который содержит код, Polyspace® флаги это. Для instance:.
int* q; //@Error int foo(void); //... void bar(void){ /* int*p = (int*) malloc(int); // Error @allocation */ }
malloc
операция, и игнорирует первый комментарий.Средство проверки полагает, что эти комментарии предназначаются для целей документации или вводимый сознательно с некоторой предусмотрительностью.
Если вы ожидаете нарушение правила, но не видите его, относитесь, чтобы Диагностировать, Почему Кодирующие Стандартные Нарушения Не Появляются как ожидалось.
Группа: проект Кода |
Категория: консультация |
Категория AGC: консультация |