Próbuję serializować i deserializować surowe wskaźniki C i ich dane, korzystając z poniższego przykładu. Wydaje się serializować, ale nie mam pewności, jak sprawić, by była deserializacją - po prostu rozbija się o wyjątek naruszenia dostępu do pamięci po deserializacji. Przypuszczam, że dzieje się tak dlatego, że nie wie, jak go przekształcić, ale gdzie mam to określić?Serializacja wzmocnienia, deserializacja surowych macierzy C
Stosując wektor nie jest opcją, w bardzo dużych danych pierwotnych kwot jest boleśnie powolny
#include <stdint.h>
#include <string>
#include <iostream>
#include <fstream>
#pragma warning (push)
#pragma warning(disable : 4244)
#include <boost/serialization/serialization.hpp>
#include <boost/serialization/vector.hpp>
#include <boost/serialization/string.hpp>
#include <boost/serialization/array.hpp>
#include <boost/archive/binary_oarchive.hpp>
#include <boost/archive/binary_iarchive.hpp>
#pragma warning (pop)
struct Monkey
{
uint32_t num;
float* arr;
};
namespace boost
{
namespace serialization
{
template<class Archive>
void serialize(Archive & ar, Monkey& m, const unsigned int version)
{
ar & m.num;
ar & make_array<float>(m.arr, m.num);
}
}
}
int _tmain(int argc, _TCHAR* argv[])
{
const char* name = "monkey.txt";
{
Monkey m;
m.num = 10;
m.arr = new float[m.num];
for (uint32_t index = 0; index < m.num; index++)
m.arr[index] = (float)index;
std::ofstream outStream(name, std::ios::out | std::ios::binary | std::ios::trunc);
boost::archive::binary_oarchive oar(outStream);
oar << (m);
}
Monkey m;
std::ifstream inStream(name, std::ios::in | std::ios::binary);
boost::archive::binary_iarchive iar(inStream);
iar >> (m);
return 0;
}
Zacząłem pisać własną odpowiedź, ale @sehe już wszystkie kod i wszystkie problemy.Mogę tylko dodać moje podsumowanie, po prostu zmieniając to, co jest tutaj: twoim prawdziwym problemem nie jest deserializacja jako taka, ale zarządzanie pamięcią. Nie określono, w jaki sposób struct Monkey przydziela, kopiuje lub zwalnia pamięć, której używa. Sehe dostarczył dwa czyste sposoby na rozwiązanie tego problemu zarządzania pamięcią (albo wektor użytkowy, albo dodaj/usuń ctor, dtor itd.). –