#include #include #include #include #include #include #include #include using namespace std; using namespace boost::archive; BOOST_CLASS_TRACKING(list, track_never) int main(int argc, char* argv[]) { char* endptr = 0; long elements; if (argc > 1) { elements = strtol(argv[1], &endptr, 10); } else { elements = 70000; } list lst; for (int j = 1; j <= elements; ++j) { lst.push_back(j*3); } filebuf fb; fb.open("ofile", ios_base::out); binary_oarchive oa(fb); //cout << "bufSize is " << fb.epptr() - fb.pbase() << endl; timeval before_tv, after_tv; struct timezone tz; gettimeofday(&before_tv, &tz); oa << lst; gettimeofday(&after_tv, &tz); if (before_tv.tv_sec != after_tv.tv_sec) { after_tv.tv_usec += 1000000; } long diff = after_tv.tv_usec - before_tv.tv_usec; cout << "That took (microseconds) " << diff << endl; return 1; }