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

 
 
> Отрицательные чила в ассемблере., Лехкий вопрос для знающего........
Potter
сообщение Feb 15 2007, 12:53
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 151
Регистрация: 27-05-06
Из: Харьков
Пользователь №: 17 508



Старший бит в байте определяет знак числа... А в одном байте может хранится значение от -127 до 127. Так вот допустим есть восьми битное число представленное в двоичном коде: 1000 0001. Вопрос - в нашем понимании это будет 1 или -1?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
NVade
сообщение Feb 15 2007, 13:02
Сообщение #2


Участник
*

Группа: Свой
Сообщений: 71
Регистрация: 7-07-06
Из: Новосибирск
Пользователь №: 18 652



Не знаю что значит "в нашем понимании", а обычное представление
-1 это 11111111, а 10000001 - это -127. Это позволяет просто складывать с отрицательными числами (на переполнение забивается).
Go to the top of the page
 
+Quote Post
Potter
сообщение Feb 15 2007, 13:12
Сообщение #3


Частый гость
**

Группа: Участник
Сообщений: 151
Регистрация: 27-05-06
Из: Харьков
Пользователь №: 17 508



Цитата(NVade @ Feb 15 2007, 14:02) *
Не знаю что значит "в нашем понимании", а обычное представление
-1 это 11111111, а 10000001 - это -127. Это позволяет просто складывать с отрицательными числами (на переполнение забивается).


Ага... 1111 1000 это -8, 1111 0110 это -10, вопрос тогда в следующем... подскаите пожалуйста... как сложить два числа в асемблере, если за ранее не известен знак чисел? Это я так понимаю надо знать как преобразовать отрецательное число в положительное?
Go to the top of the page
 
+Quote Post
_Bill
сообщение Feb 15 2007, 13:41
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 416
Регистрация: 18-04-06
Из: Челябинск
Пользователь №: 16 219



Цитата(Potter @ Feb 15 2007, 13:12) *
Цитата(NVade @ Feb 15 2007, 14:02) *

Не знаю что значит "в нашем понимании", а обычное представление
-1 это 11111111, а 10000001 - это -127. Это позволяет просто складывать с отрицательными числами (на переполнение забивается).


Ага... 1111 1000 это -8, 1111 0110 это -10, вопрос тогда в следующем... подскаите пожалуйста... как сложить два числа в асемблере, если за ранее не известен знак чисел? Это я так понимаю надо знать как преобразовать отрецательное число в положительное?

Ничего не надо преобразовывать. Сложение выполняется независимо от способа кодирования чисел, процессор "не знает" какими являются числа, без знака или с ним. Все определяется интерпретацией результата. У меня был небольшой опус на эту тему:
Об арифметике
Go to the top of the page
 
+Quote Post



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

 


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


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