|
|
  |
вывод через printf переменной unsigned long int, printf |
|
|
|
Jan 9 2013, 14:22
|
Гуру
     
Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881

|
%u - это просто "int", который архитектурно-зависимую длину имеет, в Вашем случае 16 бит. чтобы корректно вывести long int - нужна последовательность %lu
Байты так выделять некорректно - у Вас сдвиг везде на 8. Корректно - на 8, потом на 16, потом на 24. И то лишь в случае, если требуемый порядок следования байт "little endian", то есть первым по порядку следует младший байт.
UPD: Упс. Извините, не заметил, что там ">>=". Корректно байты выделять так. Но с учетом "little endian", и не факт, что оптимизатор правильно поймет и скомпилирует в оптимальную конструкцию.
|
|
|
|
|
Feb 20 2013, 11:11
|

Нечётный пользователь.
     
Группа: Свой
Сообщений: 2 033
Регистрация: 26-05-05
Из: Бровари, Україна
Пользователь №: 5 417

|
Ой, да неужели непонятно, что слова «это плохой стиль для встраиваемых систем» означают «это сделано не так, как привык тот, кто сказал, что это плохой стиль». Если не всегда, то почти всегда. Сказанные «вообще», без учета конкретных ограничений конкретной системы — всегда. Но с учётом ограничений это не «плохой стиль», а «неучёт ограничений».
Для на всякий случай хочу сразу сказать, что компы, на которых появился и сам С, и его printf в библиотеке, находятся где-то на уровне от atmega162+внешнее ОЗУ до atmega64 — по ресурсам. По быстродействию на порядок-полтора медленнее. Те компы медленнее, чем AVR-ки, а не наоборот.
--------------------
Ну, я пошёл… Если что – звоните…
|
|
|
|
|
Feb 20 2013, 11:13
|

Частый гость
 
Группа: Участник
Сообщений: 174
Регистрация: 30-08-11
Из: Санкт-Петербург
Пользователь №: 66 926

|
Цитата(messenger @ Jan 9 2013, 18:01)  bait_1 Так тоже не надо делать. Транслитерация для любых платформ является плохим стилем ReAl, нет, это значит "Это сделано не так, как рекомендует промышленный стандарт". Не нужно отвечать за меня- это тоже плохой стиль. Я сам могу.
Сообщение отредактировал Misile_Inc - Feb 20 2013, 11:14
|
|
|
|
|
Feb 20 2013, 11:16
|

Нечётный пользователь.
     
Группа: Свой
Сообщений: 2 033
Регистрация: 26-05-05
Из: Бровари, Україна
Пользователь №: 5 417

|
Цитата(Misile_Inc @ Feb 20 2013, 13:10)  Всякие стандарты типа MISRA запрещают использование функций, в прототипах которых есть многоточие (elipsis). Тогда «плохой стиль с точки зрения мисры», а не «плохой стиль для embedded вообще». Причина в том, что код с функцями с эллипсисом несколько труднее формально верифицировать, чем десять строк тупых itoa()/strlen()/put_spaces()/putstr(). Но в результате то, что можно написать одним вызовом printf, придётся писать несколькими строками вызовов разных функций и ещё неизвестно, где легче ошибку сделать как при начальном написании, так и при модификации. А GCC, например, умеет сам ругаться на несоответствие количества и типов аргументов форматной строке printf (в духе «третий спецификатор для long, а туда сунули char*»). И даже про свою функцию lcd_printf(int x, int y, const char *fmt, ...) ему можно объяснить, каким аргументом идёт форматная строка и он проверит всё.
--------------------
Ну, я пошёл… Если что – звоните…
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|