Перейти к содержанию
    

Почему не работает сдвиг битов

Добрый день!

 

unsigned long total = 0; //32bit

unsigned int part1 = 0xAABB; //16bit

unsigned int part2 = 0xCCDD; //16bit

 

total = ((part1 << 16) + part2);

 

Результат получается total = 0x0000CCDD;

 

При компиляции выдает сообщение, что слишком большой сдвиг. Если вместо 16 поставить 8, все нормально.

 

Почему не выходит сдвинуть больше 8-ми разрядов?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Добрый день!

 

unsigned long total = 0; //32bit

unsigned int part1 = 0xAABB; //16bit

unsigned int part2 = 0xCCDD; //16bit

 

total = ((part1 << 16) + part2);

 

Результат получается total = 0x0000CCDD;

 

При компиляции выдает сообщение, что слишком большой сдвиг. Если вместо 16 поставить 8, все нормально.

 

Почему не выходит сдвинуть больше 8-ми разрядов?

total = (((long)part1 << 16) + part2);

Или нет?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

При компиляции выдает сообщение, что слишком большой сдвиг.
Правильно говорит

Почему не выходит сдвинуть больше 8-ми разрядов?
На самом деле можно в вашем случае хоть на 15 разрядов. Причина - правила неявного приведения целочисленных типов (integer promotion rules). int в MSP430 имеет разрядность 16 бит. См. по ссылке 1.3.2. Преобразования при вычислении выражений

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...