КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Выполнение арифметических действий с кодами
Пример 1.14. Обратный код числа. Пример 1.13. Дополнительный код. Пример 1.12. Прямой код. Машинные коды.
Двоичные числа в ЭВМ представляются машинными кодами определённой разрядности. Предположим, что число разрядов слова равно m тогда двоичный код числа X в этой разрядности запишется следующим образом:
Здесь Xm-1 – знаковый разряд числа
Прямой код числа X определяется следующим образом:
Из (1.16) следует, что ноль имеет два представления:
Представить в прямом коде двоичные числа (+1000010)2 и (-1000010)2:
Прямые коды чисел не используются при выполнении операций над числами. Это связано с тем, что обработка цифровых и знакового разрядов чисел осуществляется по различным алгоритмам. Выполнение операций сложения и вычитания требуются двух разных устройств: сумматора и вычитателя. В силу сказанного для выполнения арифметических операций сложения и вычитания используется дополнительный или обратный код числа.
Дополнительный код числа X определяется следующим образом:
Представить в дополнительных кодах двоичные числа (+1000010)2 и (-1000010)2:
Таким образом, дополнительный код положительного числа совпадает с прямым кодом. Дополнительный код отрицательного числа образуется по следующему правилу: все младшие разряды числа до первой единицы включительно сохраняют своё значение, остальные инвертируются, а в знаковом разряде записывается единица. Ноль в дополнительном коде имеет единственное представление:
Как следует из (1.18) дополнительный код осуществляет Рис. 1.1 отображение отрицательных чисел на область положительных чисел (рис. 1.1)
Обратный код числа X определяется следующим образом:
Представить в обратном коде двоичные числа и. а) [+1000010]обр=0 1000010. б) [-1000010]обр=28-1000010-1=10 0000000-1000010-1=1 0111101.
Таким образом, обратный код положительного числа совпадает с прямым кодом, а обратный код отрицательного числа образуется по следующему правилу: все цифровые разряды числа инвертируются, а в знаковом разряде записывается единица. Ноль в обратном коде имеет два представления:
Как следует из (1.19) обратный код, также как и дополнительный, осуществляет отображение отрицательных чисел на область положительных чисел (Рис. 1.2.). Рис. 1.2 На основании (1.19) можно установить связь между обратным и дополнительным кодом,
откуда можно получить другое правило образования дополнительного кода,
Это правило используется в ЭВМ при переходе к дополнительному коду числа. Обратный и дополнительный код чисел обладают свойством линейности относительно операций сложения и вычитания
Таким образом, операции сложения и вычитания двоичных чисел заменяется операцией алгебраического сложения кодов. Поскольку представление в дополнительном или обратном кодах является беззнаковым, то операции сложения и вычитания для всех разрядов кодов выполняется по одному алгоритму.
Дата добавления: 2014-10-15; Просмотров: 291; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |