Я написал несколько целых, char [] и т. Д. В файл данных с BinaryWriter на C #. Читая файл обратно (в C #) с помощью BinaryReader, я могу прекрасно воссоздать все части файла.
Однако попытка прочитать их обратно с помощью C ++ дает некоторые страшные результаты. Я использовал fstream, чтобы попытаться прочитать данные, а данные не читались правильно. В C ++ я установил fstream с ios::in|ios::binary|ios::ate
и использовал seekg для определения местоположения. Затем я прочитал следующие четыре байта, которые были записаны как целое число «16» (и правильно читает в C #). Это читается как 1244780 в C ++ (не адрес памяти, я проверял). С чего бы это? Есть ли эквивалент BinaryReader в C ++? Я заметил, что это упомянуто в msdn, но это Visual C ++, и intellisense для меня даже не выглядит как c ++.
Пример кода для записи файла (C #):
public static void OpenFile(string filename)
{
fs = new FileStream(filename, FileMode.Create);
w = new BinaryWriter(fs);
}
public static void WriteHeader()
{
w.Write('A');
w.Write('B');
}
public static byte[] RawSerialize(object structure)
{
Int32 size = Marshal.SizeOf(structure);
IntPtr buffer = Marshal.AllocHGlobal(size);
Marshal.StructureToPtr(structure, buffer, true);
byte[] data = new byte[size];
Marshal.Copy(buffer, data, 0, size);
Marshal.FreeHGlobal(buffer);
return data;
}
public static void WriteToFile(Structures.SomeData data)
{
byte[] buffer = Serializer.RawSerialize(data);
w.Write(buffer);
}
Я не уверен, как я могу показать вам файл данных.
Пример чтения данных обратно (C #):
BinaryReader reader = new BinaryReader(new FileStream("C://chris.dat", FileMode.Open));
char[] a = new char[2];
a = reader.ReadChars(2);
Int32 numberoffiles;
numberoffiles = reader.ReadInt32();
Console.Write("Reading: ");
Console.WriteLine(a);
Console.Write("NumberOfFiles: ");
Console.WriteLine(numberoffiles);
Это я хочу выполнить на С ++. Начальная попытка (неудача с первого целого числа):
fstream fin("C://datafile.dat", ios::in|ios::binary|ios::ate);
char *memblock = 0;
int size;
size = 0;
if (fin.is_open())
{
size = static_cast<int>(fin.tellg());
memblock = new char[static_cast<int>(size+1)];
memset(memblock, 0, static_cast<int>(size + 1));
fin.seekg(0, ios::beg);
fin.read(memblock, size);
fin.close();
if(!strncmp("AB", memblock, 2)){
printf("test. This works.");
}
fin.seekg(2); //read the stream starting from after the second byte.
int i;
fin >> i;
Редактировать: Кажется, что независимо от того, в каком месте я использую «seekg», я получаю одно и то же значение.