Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.08.11;
Скачать: CL | DM;

Вниз

FormatCurr   Найти похожие ветки 

 
Сорокин Семен   (2003-07-30 10:37) [0]

var
_a : currency;
...
_a := 5.325;
ShowMessage(FormatCurr("0.00", _a)); //результат 5.32
_a := 5.3251;
ShowMessage(FormatCurr("0.00", _a)); //результат 5.33
_a := 5.315;
ShowMessage(FormatCurr("0.00", _a)); //результат 5.32
Ф-я FormatFloat отрабатывает как надо.
Тесты ф-ии FormatCurr привели к тому что если 2-я цифра после запятой - четная, то округление (в случае следующей -последней 5-ки) идет в меньшую сторону, а если нечетная - тов большую. Может быть внутреннее представление чисел выглядит как 5.32499999999999 и 5.3150000000000 соответственно, хотя у currency вроде только 4 значащих цифры, тогда не ясно при чем здесь четность предыдущей цифры?
Это бага или фича?
Типа каждая четная копейка в пользу считающего :))))
У кого есть какие соображения?


 
Anatoly Podgoretsky ©   (2003-07-30 10:41) [1]

А каждая нечетная в пользу плательщика, что в сумме дает плюс на мину.
Это наиболее часто используемое округление, поскольку дает меньшую ошибку на массиве чисел.
Вариаранты 5.32499999999999 или 5.32500000000001 сюда не относятся, только 5,325000000000000


 
BillyJeans ©   (2003-07-30 10:53) [2]

Используй SimpleRoundTo, в D7 она точно имеется..



Страницы: 1 вся ветка

Текущий архив: 2003.08.11;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.011 c
14-33323
GebbelZ
2003-07-24 00:21
2003.08.11
дополнительные кнопки клавиатуры & WinAmp


14-33357
Donor
2003-07-25 16:51
2003.08.11
dll


1-33153
IgorRu
2003-07-26 21:37
2003.08.11
Как сохранить Форму в файл и затем в работающем проекте восст....


1-33156
Альф
2003-07-25 16:12
2003.08.11
Как ограничить перемещение по гриду ???


1-33181
Maxi-mov
2003-07-27 00:06
2003.08.11
Как из моего приложения редакторовать ячейку Excel ?