- чтение/конвертирование бинарных данных из файла, jd, 21:41 , 10-Июн-07 (1)
Что вы понимаете под конвертацией в int? Если имеется в виду, что вы читаете из файла двухбайтовое целое значение, то почему бы его не считать сразу в переменную типа int?int val = 0; rStream.read(&val, 2); // хотя вообще-то работоспособность этого кода зависит от платформы и зачем вы делаете seekg(0) сразу после открытия файла??
- чтение/конвертирование бинарных данных из файла, елка, 21:46 , 10-Июн-07 (2)
>Что вы понимаете под конвертацией в int? Если имеется в виду, что >вы читаете из файла двухбайтовое целое значение, то почему бы его >не считать сразу в переменную типа int? > >int val = 0; >rStream.read(&val, 2); // хотя вообще-то работоспособность этого кода зависит от платформы > >и зачем вы делаете seekg(0) сразу после открытия файла?? платформа linux, read считывает в char и считывание в int вываливает в ошибку ((
- чтение/конвертирование бинарных данных из файла, jd, 22:10 , 10-Июн-07 (3)
>платформа linux, read считывает в char >и считывание в int вываливает в ошибку (( Под платформой я имел в виду скорее процессор. Будем считать, что это IA32 (то есть какой-нибудь обычный интеловский процессор или типа того). Чтобы не ругалось, нужно сделать: rStream.read((char*)&val, 2);
- чтение/конвертирование бинарных данных из файла, елка, 22:26 , 10-Июн-07 (4)
спасибо, получается теперь осталось изменить порядок следования байтов на обратный т.к. считывая с файла 01 EB получаю 60161 вместо 491т.е. после считывания к int конвертирует EB 01 (в файле 01 EB)
- чтение/конвертирование бинарных данных из файла, jd, 23:35 , 10-Июн-07 (5)
>теперь осталось изменить порядок следования байтов на обратный >т.к. считывая с файла 01 EB >получаю 60161 >вместо 491 > >т.е. после считывания к int конвертирует EB 01 (в файле 01 EB) Поэтому я и говорил с самого начала про платформу и про "Что вы понимаете под конвертацией в int?". Порядок следования байт - штука относительная. На интеловской архитектуре всё именно так, как вы говорите, то есть по меньшему адресу находится младший байт, по большему - старший. Таким образом результат, полученный вами, предсказуем и корректен с точки зрения интел. Другое дело, что вам, вероятно нужен другой результат (ведь задачу ставит не производитель процессоров), поэтому нужно точнее описывать, что вы хотите получить. Короче, если не забивать голову, можете просто сделать так: unsigned char doublebuf[2] = {0}; // обратите внимание на то, что doublebuf теперь unsigned char[] ifstream rStream( pathfile.c_str(), ios::in | ios::binary ); rStream.read( (char*)doublebuf, 2 ) int n = ((int)doublebuf[0] << 8) | buf[1]; или, используя предыдущий вариант (где целое значение уже получено, но байты не в том порядке), можно сделать так:
int n = 0; rStream.read((char*)&n, 2); n = ((n & 0xff) << 8) | (n >> 8); // меняем два младших байта местами (старшие байты равны нулю) А вообще настоятельно рекомендую почитать академическую литературу. Всё это - основы и без понимания их - никуда.
- чтение/конвертирование бинарных данных из файла, jd, 23:55 , 10-Июн-07 (6)
Можно ещё сделать так:int n = 0; rStream.read(((char*)&n) + 1, 1); rStream.read((char*)&n, 1); Или так:
#include <stdint.h> ... char doublebuf[2]={0}; rStream.read(doublebuf + 1, 1); rStream.read(doublebuf, 1); int n = (int)*(uint16_t*)doublebuf; Или ещё каким-нибудь из миллиона (извращенских) способов... :)
|