Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
LASpace
34 / 34 / 3
Регистрация: 27.01.2013
Сообщений: 142
#1

Порядок байтов в машинном слове - C++

17.06.2013, 15:52. Просмотров 934. Ответов 7
Метки нет (Все метки)

есть структура
C++
1
2
3
4
5
6
7
struct V {
    unsigned short int i1, i2; // одно 16-разрядное слово на элемент
    unsigned int i3, i4; // два 16-разрядных слова на элемент
    double i5, i6, i7, i8; // четыре 16-разрядных слова на элемент
    float i9, i10, i11, i12, i13, i14, i15, i16, i17, i18, i19, i20; // два 16-разрядных слова на элемент
 
};
нужно ее элементы записать в файл при этом каждое 16-разрядное слово подать младшим байтом вперед...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.06.2013, 15:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Порядок байтов в машинном слове (C++):

Порядок байтов - C++
Заранее извиняюсь если не туда пишу... Помогите определить порядок байтов: 01 00 00 00 71 82 3D 00 CB 82 3D 00 ED 68 4C 23...

порядок байтов - C++
Подскажите, пожалуйста, как записать целое число в битовый файл, чтобы на всех машинах оно считывалось бы с одинаковым порядком байт.

Задать порядок байтов - C++
Нет ли в C++ какого-то штатного средства, позволяющего преобразовать порядок байт числа в "от старшего к младшему"? Понятно, что...

Перевод байтов в сетевой порядок и обратно - C++
Вообщем нужно переводить массив байтов, сделал так : union bits { unsigned int number; unsigned char buff; }; void...

Порядок байт в слове и бит в байте - C++
читал эту требуются пояснения. A B C D - адреса в них число 128 BE A B C D ...

Расшифровать сообщение: поменять порядок букв в слове наоборот - C++
Дан массив символов, содержащий текст. Слова зашифрованы – каждое из них записано наоборот. Расшифровать сообщение.

7
kzru_hunter
1102 / 771 / 58
Регистрация: 01.02.2011
Сообщений: 1,779
Записей в блоге: 1
17.06.2013, 16:02 #2
Цитата Сообщение от LASpace Посмотреть сообщение
при этом каждое 16-разрядное слово подать младшим байтом вперед...
зачем? задание такое?
0
LASpace
34 / 34 / 3
Регистрация: 27.01.2013
Сообщений: 142
17.06.2013, 16:06  [ТС] #3
это руководство требует... у них железяка только так прочитать сможет эти числа...
записать проблем нет)
C++
1
2
3
4
5
6
7
FILE *F;
F = fopen("MPO", "wb");
V iV;
fwrite(iV.i1, 2, 1, F);
fwrite(iV.i2, 2, 1, F);
fwrite(iV.i3, 4, 1, F);
//и так далее
а вот как младшим байтом вперед сделать хз...
говорят как то union используют, но как опять же не пойму
0
kzru_hunter
1102 / 771 / 58
Регистрация: 01.02.2011
Сообщений: 1,779
Записей в блоге: 1
17.06.2013, 17:13 #4
Т.к. у тебя в структуре нету однобайтовых переменных, то подойдет эта функция для преобразования структуры:
C++
1
2
3
4
5
6
7
8
9
V ConvertToBigEndian(V v)
{
        USHORT *p = reinterpret_cast<USHORT *>(&v);
        for ( UINT i = 0; i < sizeof(v)/2; i++ )
        {
                p[i] = htons(p[i]);
        }
        return v;
}
1
nick42
Практикантроп
4126 / 2159 / 208
Регистрация: 23.09.2011
Сообщений: 4,622
17.06.2013, 17:26 #5
Цитата Сообщение от LASpace Посмотреть сообщение
при этом каждое 16-разрядное слово подать младшим байтом вперед
Двухбайтовые слова так и передаются в устройство вывода: сначала младший, затем старший байт. Воспроизведите такой код и посмотрите в hex-редакторе на полученный файл:__
C++
1
2
3
4
   short gg[16]={ 17,14,6,2,18,9,11,16,7 };
   FILE *F;
   if ((F = fopen("mobi.bin","w+b"))!=0) fwrite(gg,10,1,F);
   fclose(F);
0
kzru_hunter
1102 / 771 / 58
Регистрация: 01.02.2011
Сообщений: 1,779
Записей в блоге: 1
17.06.2013, 17:27 #6
Цитата Сообщение от nick42 Посмотреть сообщение
Двухбайтовые слова так и передаются в устройство вывода: сначала младший, затем старший байт.
Ему нужно сначала старший, потом младший (т.е. младший впереди старшего)
Цитата Сообщение от kzru_hunter Посмотреть сообщение
то подойдет эта функция для преобразования структуры:
кстати, эта функция подойдет также для обратного преобразования
0
LASpace
34 / 34 / 3
Регистрация: 27.01.2013
Сообщений: 142
18.06.2013, 10:11  [ТС] #7
Цитата Сообщение от kzru_hunter Посмотреть сообщение
p[i] = htons(p[i]);
А в какой библиотеке функция htons?
0
kzru_hunter
1102 / 771 / 58
Регистрация: 01.02.2011
Сообщений: 1,779
Записей в блоге: 1
18.06.2013, 11:26 #8
Цитата Сообщение от LASpace Посмотреть сообщение
А в какой библиотеке функция htons?
в хелпе же написано, winsock2.h
1
18.06.2013, 11:26
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.06.2013, 11:26
Привет! Вот еще темы с ответами:

Переписать содержимое одной строки в другую изменив порядок букв в первом слове на обратный - C++
Нужно написать программу на С++ переписать содержимое одной строки в другую изменив порядок букв в первом слове на обратный

Преобразовать все слова массива так, чтобы каждый символ в слове повторялся один раз, сохранив общий порядок следования символов - C++
здраствуйте,программисты.помогите решить любую из приведённых задач,может кто делал подобные программы и сохранился готовый код?задание...

Порядок отрицательных членов изменить на обратный, порядок неотрицательных сохранить - C++
Задача (нужно все 3 пункта в 1 программе сделать) Прошу Помочь В условиях задания 3 а) порядок отрицательных членов изменить на...

Чтение байтов - C++
Ребят, здравствуйте , nомогите разобраться , есть бинарный файл , в нем данные заnисанные в структурах , и в файле 1-е 4 байта это кол-во...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.