Форум программистов, компьютерный форум CyberForum.ru

Совместимость char и unsigned char - C++

Восстановить пароль Регистрация
 
Vtulhu
369 / 375 / 96
Регистрация: 12.08.2011
Сообщений: 1,610
07.12.2012, 11:01     Совместимость char и unsigned char #1
Есть некие числа в виде unsigned char. Есть строка в виде массива char (которая потом сбрасывается в файл с помощью fputs). В программе происходит преобразование чисел в строки. При этом используются побитовые операции. Результаты не всегда совпадают с ожидаемыми. Вот я и думаю - в чём причина? Вроде ничего не напутал. Я так предполагаю, что при копировании числа из unsigned char в char оно никак не преобразовывается, совпадая бит в бит?

C++
1
2
3
4
5
6
7
8
9
unsigned char x = 111;
unsigned char y = 222;
const char SYMBOLS[] = "0123456789ABCDEF";
char Line[3];
Line[2] = x ^ y;  // используется в качестве временной переменной
Line[0] = SYMBOLS[Line[2] >> 4];
Line[1] = SYMBOLS[Line[2] & 15];
Line[2] = '\0';
fputs(Line, file);
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.12.2012, 11:01     Совместимость char и unsigned char
Посмотрите здесь:

C++ Работа с unsigned char
C++ unsigned char 0....255?!
C++ const char и unsigned char
C++ Unsigned char to vector
C++ Std::fstream почему функция write принимает параметр char* а не unsigned char* (аля byte*) ?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11841 / 6820 / 771
Регистрация: 27.09.2012
Сообщений: 16,911
Записей в блоге: 2
Завершенные тесты: 1
07.12.2012, 11:15     Совместимость char и unsigned char #2
Цитата Сообщение от Vtulhu Посмотреть сообщение
Есть некие числа в виде unsigned char. Есть строка в виде массива char (которая потом сбрасывается в файл с помощью fputs). В программе происходит преобразование чисел в строки. При этом используются побитовые операции. Результаты не всегда совпадают с ожидаемыми. Вот я и думаю - в чём причина? Вроде ничего не напутал. Я так предполагаю, что при копировании числа из unsigned char в char оно никак не преобразовывается, совпадая бит в бит?
При сдвиге положительного числа вправо, старшие разряды заполняются нулями, при сдвиге отрицательного - единицами, возможно в этом причина
ValeryS
Модератор
6377 / 4843 / 442
Регистрация: 14.02.2011
Сообщений: 16,053
07.12.2012, 12:09     Совместимость char и unsigned char #3
Цитата Сообщение от Croessmah Посмотреть сообщение
При сдвиге положительного числа вправо, старшие разряды заполняются нулями, при сдвиге отрицательного - единицами, возможно в этом причина
копируется знаковый бит справедливо для signed
для unsigned записываются 0

проверяется очень просто сдвиг влево это деление на степень 2
например
-2/2 тоже самое -2>>1
0xFE(-2)>>1 =0xFF (-1)
unsigned
0xFE(254)>>1 =0x7F (127)
Croessmah
07.12.2012, 12:18
  #4

Не по теме:

Цитата Сообщение от ValeryS Посмотреть сообщение
копируется знаковый бит справедливо для signed
для unsigned записываются 0
не так выразился(положительное-без знаковое и отрицательное-знаковое отрицательное)
Хотя с другой стороны, все там правильно. Ибо без знаковое число всегда положительное, а в знаковом только при сдвиге отрицательного появляются Ыдинички...

Vtulhu
369 / 375 / 96
Регистрация: 12.08.2011
Сообщений: 1,610
07.12.2012, 14:44  [ТС]     Совместимость char и unsigned char #5
Цитата Сообщение от Croessmah Посмотреть сообщение
При сдвиге положительного числа вправо, старшие разряды заполняются нулями, при сдвиге отрицательного - единицами, возможно в этом причина
Наверняка именно это! Спасибо, что просветили, хоть я и подозревал нечто подобное! Вариантов решения вижу два:
1. После сдвига отбрасывать левые биты, т.е. Line[0] = SYMBOLS[(Line[2] >> 4) & 15];
2. Использовать строку из unsigned char. Вот только я не уверен, нормально ли это воспримется функцией fputs.
ValeryS
Модератор
6377 / 4843 / 442
Регистрация: 14.02.2011
Сообщений: 16,053
07.12.2012, 14:51     Совместимость char и unsigned char #6
Цитата Сообщение от Vtulhu Посмотреть сообщение
1. После сдвига отбрасывать левые биты, т.е. Line[0] = SYMBOLS[(Line[2] >> 4) & 15];
зачем так сложно
приводишь к unsigned char сдвигаешь приводишь к char
Цитата Сообщение от Vtulhu Посмотреть сообщение
Использовать строку из unsigned char. Вот только я не уверен, нормально ли это воспримется функцией fputs.
а ей по барабану, главное размер

Добавлено через 1 минуту
Цитата Сообщение от ValeryS Посмотреть сообщение
SYMBOLS[(Line[2] >> 4) & 15];
как то так
C++
1
SYMBOLS[(char)((unsigned char)Line[2] >> 4)]
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.12.2012, 15:28     Совместимость char и unsigned char
Еще ссылки по теме:

C++ Unsigned char to string
Аргумент типа "unsigned char*" несовместим с параметром типа "const char*" C++
C++ Приведение типов unsigned char[2] to unsigned char [64]

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

Или воспользуйтесь поиском по форуму:
Vtulhu
369 / 375 / 96
Регистрация: 12.08.2011
Сообщений: 1,610
07.12.2012, 15:28  [ТС]     Совместимость char и unsigned char #7
А самый просто способ - использовать дополнительную переменную типа unsigned char. Ох уж это моё крохоборство. Тяжёлое детство, восьмибитные компьютеры, загружающиеся с магнитофона.

C++
1
2
3
4
5
6
7
8
unsigned char x = STATE_USER[0];
Line[0] = SYMBOLS[x >> 4];
Line[1] = SYMBOLS[x & 15];
Line[2] = ' ';
x = STATE_USER[1];
Line[3] = SYMBOLS[x >> 4];
Line[4] = SYMBOLS[x & 15];
Line[5] = '\0';
Yandex
Объявления
07.12.2012, 15:28     Совместимость char и unsigned char
Ответ Создать тему
Опции темы

Текущее время: 06:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru