我有以下测试用例,它将一个int序列化为std:vector
。
由于以下断言而崩溃:
serialization_test: /usr/include/boost/iostreams/detail/optional.hpp:55: T& boost::iostreams::detail::optional<T>::operator*() [with T = boost::iostreams::detail::concept_adapter<boost::iostreams::back_insert_device<std::vector<char> > >]: Assertion `initialized_' failed.
有什么想法吗?我认为这应该有效...
BOOST_AUTO_TEST_CASE(serialize_base_test)
{
int t = 42;
std::vector<char> buffer;
iostreams::back_insert_device<std::vector<char>> sink{buffer};
iostreams::stream<iostreams::back_insert_device<std::vector<char>>> os;
os.open(sink);
archive::binary_oarchive oa(os);
oa << t;
os.flush();
os.close();
}
编辑:我简化了测试用例。
答案 0 :(得分:2)
应该在关闭流之前调用存档的析构函数,因为它会将所有更改的流方面恢复到打开存档之前的状态。
答案 1 :(得分:1)
好吧,我知道了。 import promiseMiddleware from 'redux-promise-middleware';
composeStoreWithMiddleware = applyMiddleware(
promiseMiddleware,
)(createStore);
在其析构函数内执行某些操作,要求该流仍处于打开状态。
以下作品:
binary_oarchive