|
Можно ли в keil разбить #define на несколько строк ? |
|
|
|
Sep 28 2013, 11:08
|
Гуру
     
Группа: Свой
Сообщений: 2 360
Регистрация: 6-03-06
Из: Кишинев
Пользователь №: 15 025

|
Цитата(igorle @ Sep 28 2013, 12:22)  Ruslan1, выше был пример. Но я повторю его, так как выше смешал два случая: Код #define aaa() { printf("XXX\n"); } if (1) aaa(); else printf("Yo are so wrong\n"); просто не скомпилируется. Это не интересно. Я спросил пример кода, где определенный так макрос будет работать некорректно. То есть когда оно работает, но некорректно. То есть компилятор молча пережевал и сгенерировал код, но код работает не так как задумывал программист. Варианты, которые детектируются любым компилятором как варнинги или ошибки не интересны, так как очевидно, что любой даже варнинг требует внимания программиста и документирования как допустимый или модификации кода для его устранения. Вот если Вы укажете компилятор, в котором приведенный Вами пример не сгенерирует варнинг или ошибку (и, само собой, работать будет некорректно)- я с Вами соглашусь.
|
|
|
|
|
Sep 28 2013, 11:50
|
Знающий
   
Группа: Свой
Сообщений: 702
Регистрация: 8-06-06
Пользователь №: 17 871

|
Цитата(Ruslan1 @ Sep 28 2013, 15:08)  Это не интересно. Я спросил пример кода, где определенный так макрос будет работать некорректно. То есть когда оно работает, но некорректно. К чему такие придирки? Или если написано "чуть-чуть неправильно" - то так делать можно, а вот если "совсем неправильно" - уже нельзя? Очевидно, что простой блок в макросах способен вызвать проблемы, знать об этом и осознанно писать проблемные макросы - как минимум странно. С точки зрения повторного использования будет не важно, код не компилируется, или компилируется, но работает некорректно. Это влияет только на скорость выявления проблем. Все равно придется лезть в чужой (или в свой старый) макрос и его исправлять, или переписывать код так, чтобы после макроса не было точки с запятой. И зачем это нужно, если есть старый как сам C способ написания корректного кода? http://c-faq.com/cpp/multistmt.htmlО нем можно не знать, это нормально. Но знать и не использовать - в чем выгода?
|
|
|
|
|
Sep 28 2013, 15:38
|
Местный
  
Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753

|
Поддерживаю предыдущего оратора. И еще. "функции" без точки с запятой в конце, сбивают механизм автоматической индентации. Например, я сейчас напечатал в виме код, и он выровнял мне его так: Код if (1) aaa() bbb(); А это некрасиво. И это уже достаточный повод не делать этого.
|
|
|
|
|
Sep 29 2013, 20:22
|

Знающий
   
Группа: Участник
Сообщений: 974
Регистрация: 4-04-08
Из: далека
Пользователь №: 36 467

|
Цитата(igorle @ Sep 28 2013, 05:22)  А вывод один - обрамляйте любую макрофункцию, состоящую более чем из вызова одной функции, do {} while(0), и будет вам счастье. Не согласен. После if всегда надо пользовать фигурные скобки. Назвисимо от использования всяких define. Это улучшает читаемость и предсказуемость кода. Чем больше напихано в #define, тем сложнее их читать. То, что компилятор не скомпилирует не проблема. поправим. Проблема если скомпилирует не так как надо.
--------------------
Верить нельзя никому, даже себе. Мне - можно.
|
|
|
|
|
Sep 29 2013, 20:56
|
Гуру
     
Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448

|
Цитата(A. Fig Lee @ Sep 30 2013, 00:22)  После if всегда надо пользовать фигурные скобки. ... Это улучшает читаемость и предсказуемость кода. Код if(x) zzz(); По-моему, в подобном выражении фигурные скобки не улучшат читаемость. Скорее, наоборот. Цитата(A. Fig Lee @ Sep 30 2013, 00:22)  То, что компилятор не скомпилирует не проблема. поправим. Проблема если скомпилирует не так как надо. Если что-то надо править, то это все равно проблема. Она, конечно, меркнет на фоне второго варианта развития событий, но все же.
|
|
|
|
|
Sep 29 2013, 21:16
|
Местный
  
Группа: Свой
Сообщений: 437
Регистрация: 27-08-04
Пользователь №: 551

|
QUOTE (A. Fig Lee @ Sep 29 2013, 23:22)  Не согласен. После if всегда надо пользовать фигурные скобки. Назвисимо от использования всяких define. Это улучшает читаемость и предсказуемость кода. Чем больше напихано в #define, тем сложнее их читать.
То, что компилятор не скомпилирует не проблема. поправим. Проблема если скомпилирует не так как надо. Маладец! Герой! Аплодирую стоя, один прет против всех! Прям как макаревич в своих нетленках. Теперь нужно срочно наставить на путь истинный девелоперов линукс ядра, lwip, contiki и т.д. Залезть в их репозитории и поубивать ненавистные дувайлы
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|