http://stxxl.sourceforge.net
<dementiev@ira.uka.de>
<beckmann@cs.uni-frankfurt.de>
http://www.boost.org/LICENSE_1_0.txt
#include <iterator>
#include <stxxl/deque>
int main(int argc, char* argv[])
{
if (argc != 2) {
STXXL_MSG("Usage: " << argv[0] << " #ops");
return -1;
}
stxxl::deque<int> Deque;
stxxl::deque<int>::const_iterator b = Deque.begin();
stxxl::deque<int>::const_iterator e = Deque.end();
STXXL_CHECK(b == e);
Deque.push_front(1);
Deque.push_front(2);
Deque.push_front(3);
b = Deque.begin();
STXXL_CHECK(b != e);
Deque.push_back(5);
std::copy(Deque.begin(), Deque.end(), std::ostream_iterator<int>(std::cout, " "));
stxxl::random_number32 rand;
stxxl::deque<int> XXLDeque;
std::deque<int> STDDeque;
stxxl::uint64 ops = stxxl::atouint64(argv[1]);
for (stxxl::uint64 i = 0; i < ops; ++i)
{
unsigned curOP = rand() % 6;
unsigned value = rand();
switch (curOP)
{
case 0:
case 1:
XXLDeque.push_front(value);
STDDeque.push_front(value);
break;
case 2:
XXLDeque.push_back(value);
STDDeque.push_back(value);
break;
case 3:
if (!XXLDeque.empty())
{
XXLDeque.pop_front();
STDDeque.pop_front();
}
break;
case 4:
if (!XXLDeque.empty())
{
XXLDeque.pop_back();
STDDeque.pop_back();
}
break;
case 5:
if (XXLDeque.size() > 0)
{
stxxl::deque<int>::iterator XXLI = XXLDeque.begin() + (value % XXLDeque.size());
std::deque<int>::iterator STDI = STDDeque.begin() + (value % STDDeque.size());
*XXLI = value;
*STDI = value;
unsigned value1 = rand();
if (XXLI - XXLDeque.begin() == 0)
break;
XXLI = XXLI - (value1 % (XXLI - XXLDeque.begin()));
STDI = STDI - (value1 % (STDI - STDDeque.begin()));
*XXLI = value1;
*STDI = value1;
}
break;
}
STXXL_CHECK(XXLDeque.empty() == STDDeque.empty());
STXXL_CHECK(XXLDeque.size() == STDDeque.size());
STXXL_CHECK(XXLDeque.end() - XXLDeque.begin() == STDDeque.end() - STDDeque.begin());
if (XXLDeque.size() > 0)
{
STXXL_CHECK(XXLDeque.back() == STDDeque.back());
STXXL_CHECK(XXLDeque.front() == STDDeque.front());
}
if (!(i % 100000))
{
STXXL_CHECK(std::equal(XXLDeque.begin(), XXLDeque.end(), STDDeque.begin() _STXXL_FORCE_SEQUENTIAL));
STXXL_MSG("Operations done: " << i << " size: " << STDDeque.size());
}
}
return 0;
}
template class stxxl::deque<int>;
typedef stxxl::deque<int> deque_type;
template class stxxl::deque_iterator<deque_type>;
template class stxxl::const_deque_iterator<deque_type>;