Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/25: Рейтинг темы: голосов - 25, средняя оценка - 4.60
Prober

Преобразование дробного числа к целому дает неожиданные результаты

27.06.2012, 21:51. Показов 4843. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, уважаемые.
Помогите, кого не затруднит, разобраться в следующем моменте.
Дело вроде примитивное, но понять не получается...
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
static void Main(string[] args)
        {
            static float fnum;
            static float fnum2;
 
            static int num;
            static int num2;
            
            //задаем значения
            fnum = (float)655.35;
            fnum2 = (float)655.34;
 
            //проводим мат.преобразование
            fnum = fnum * 100;
            fnum2 = fnum2 * 100;
 
            //выводим, чтобы поглядеть в консольке
            Console.WriteLine(fnum);
            Console.WriteLine(fnum2);
 
            // приводим к инту явно - ну надо чтобы были целыми
            num = (int)fnum;
            num2 = (int)fnum2;
            
            // смотрим приведенные значения - WTF???
            Console.WriteLine(num);
            Console.WriteLine(num2);
        }
Вывод получается следующим:
65535
65534
65534
65534
Почему инты приняли такие значения (две последние цифры) - что стало с первым из значений - 65535? Ведь это не int16 и младший бит никак не может быть отведен под знак...
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.06.2012, 21:51
Ответы с готовыми решениями:

Преобразование string в int с отбрасыванием дробного числа
Всем привет есть переменная humidity типа string,она получает данные из регулярки,всё хорошо,но стала проблема нужно получить из неё...

Преобразование денежной суммы, заданной в виде дробного числа, в формат «рубли – копейки»
Разрабатывается приложение «Lab02_02», которое: 1) имеет интерфейс, разработанный с применением визуальных компонентов Label, Button и...

преобразование дробного в целое
каким оператором можно преобразовать дробное число в целое, или откинуть дробную часть? Подскажите плиз...

3
 Аватар для Alex_Sabaka
638 / 499 / 77
Регистрация: 28.07.2010
Сообщений: 895
27.06.2012, 22:05
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
            float fnum;
            float fnum2;
 
            int num;
            int num2;
            
            //задаем значения
            fnum = (float)655.35;
            fnum2 = (float)655.34;
 
            //проводим мат.преобразование
            fnum = fnum * 100;
            fnum2 = fnum2 * 100;
 
            //выводим, чтобы поглядеть в консольке
            Console.WriteLine(fnum);
            Console.WriteLine(fnum2);
 
            // приводим к инту явно - ну надо чтобы были целыми
            num = (int)Math.Round(fnum);
            num2 = (int)Math.Round(fnum2);
            
            // смотрим приведенные значения - WTF???
            Console.WriteLine(num);
            Console.WriteLine(num2);
            Console.ReadKey();
Вот так работает. По-моему это особенности IEEE
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.06.2012, 22:28
Особенности чисел с плавающей точкой: 655.35 * 100 = 65534.9961, при касте дробная часть отбрасывается.
Вместо каста используйте Convert.ToInt32 - он округлит до ближайшего целого.
1
Prober
27.06.2012, 22:44
Ок.
Спасибо за информацию - буду знать.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.06.2012, 22:44
Помогаю со студенческими работами здесь

Преобразование дробного выражения
Здравствуйте. Мой вопрос следующий. Как преобразовать выражение вида: (a+b*j)/(c+d*j) в выражение вида: x+y*j. Вопрос жизни и смерти....

Как матлаб быстрее дает результаты
Здравствуйте, коллеги! Мне нужна ваша помощь! Задача о том, что написать модель сигнал М-ФМ + белый гауссовский шум + гармоническая...

Функция rand() дает странные результаты
Есть класс Owner с таким конструктором, значения его членов определяются рандомно. В main.cpp создаются и выводятся на экран...

Сравнение строк и StringBuilder дает разные результаты
Есть такой код: String str1 = "String"; String str2 = "String"; StringBuilder builder1 = new...

Указатели и массивы: почему заданный код даёт разные результаты?
Почему этот код даёт разные результаты? Что присваивается указателю во втором случае? int main() { char* mass =...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru