Перейти к содержанию
    

if-if-else

Есть конструкция вида

if( AAA )
   if( BBB)
       Var1 = f1(...);
   else
       Var1 = f2(...);

Код работает правильно, как и ожидается.

 

Но IAR выдает предупреждение касаемо сомнительности принадлежности else

к первому или второму if.

 

(?) Это "бдение" компилятора / подсказка разработчику на возможную логическую ошибку

или в принципе неправильное/неграмотное построение конструкции на if ?

(надо использовать { . . . })

Изменено пользователем k155la3

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Это "бдение" компилятора / подсказка разработчику на возможную логическую ошибку
Да. Иногда оказывается полезным (if(a = 2) вместо if(a == 2)). gcc иногда даже на форматирование внимание обращает, вот на такой код может предупреждение выдать:

if(...)
    expression 1;
    expression 2;

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Да. .....

Спасибо за инф.

Своим коллегам часто повторяю "компилятор умнее нас" :)

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Это именно предупреждение, иначе была бы ошибка.

Я лично никогда не видел, чтобы компилятор обращал внимание на форматирование,

всегда думал, что он сначала все переводит в одну длинную строку.

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

 

if( AAA ) {
   if( BBB)
       Var1 = f1(...);
   else
       Var1 = f2(...); }

if( AAA ) {
   if( BBB)
       Var1 = f1(...); }
   else
       Var1 = f2(...);

Первый вариант равнозначен вашему, а второй отличается.

Скобки лучше ставить явно.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...