реклама на сайте
подробности

 
 
> Снова по преобразованию типов )
TeddyIn
сообщение Jan 7 2009, 14:28
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 31
Регистрация: 4-01-09
Из: Владивосток
Пользователь №: 42 911



к примеру

Код
unsigned int f, a,b,c;

f = ((a+b)*c*a)/6556


в итоге нужно, чтобы f осталась unsigned int (известно, результат влазит в размерность unsigned int ) но по ходу вычислений образуются значения, превышающие этот тип, поэтому

Код
unsigned int f, a,b,c;

f = (( (unsigned long int)a+(unsigned long int)b)*(unsigned long int)c*(unsigned long int)a)/6556


А f же все равно должна получиться unsigned int. - Правильно ли я понимаю, и увеличится ли объем программной памяти, если использовать описанное явное приведение по сравнению с первым вариантом?


--------------------
висячий монтаж -> лак - > ЦЛ - > ЛУТ - > ФР - > ?
оу -> стабилизаторы - > драйверы -> микроконтроллеры - > ?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
_Pasha
сообщение Jan 7 2009, 14:42
Сообщение #2


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Цитата(TeddyIn @ Jan 7 2009, 18:28) *
Правильно ли я понимаю, и увеличится ли объем программной памяти, если использовать описанное явное приведение по сравнению с первым вариантом?

crying.gif Мне это тоже мешает жить во многих случаях. Про объем можно не переживать, т.к. mul32 может ведь где-то еще использоваться, а про время выполнения...
В общем, в любом случае, нужно явное приведение типов, но достаточно так:
Код
f =  (unsigned long int)(a+b)*c*a/6556

А компиляторы - вон, EWAVR 5.20, "сообразил", что надо , остальные - нет. Пример для EWAVR vs WinAVR как раз из-за того, что там это из самых актуальных вопросов.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th July 2025 - 21:36
Рейтинг@Mail.ru


Страница сгенерированна за 0.01385 секунд с 7
ELECTRONIX ©2004-2016