2016-07-02 05:05:03 +08:00
|
|
|
#include <iostream>
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
#include "data_structures/concurrent/concurrent_set.hpp"
|
2016-08-20 02:09:24 +08:00
|
|
|
#include "logging/default.hpp"
|
|
|
|
#include "logging/streams/stdout.hpp"
|
2016-07-02 05:05:03 +08:00
|
|
|
|
|
|
|
using std::cout;
|
|
|
|
using std::endl;
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
void print_skiplist(const ConcurrentSet<int>::Accessor &skiplist)
|
2016-07-02 05:05:03 +08:00
|
|
|
{
|
|
|
|
cout << "---- skiplist set now has: ";
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
for (auto &item : skiplist)
|
2016-07-02 05:05:03 +08:00
|
|
|
cout << item << ", ";
|
|
|
|
|
|
|
|
cout << "----" << endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2016-08-20 02:09:24 +08:00
|
|
|
logging::init_async();
|
|
|
|
logging::log->pipe(std::make_unique<Stdout>());
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
ConcurrentSet<int> set;
|
2016-07-02 05:05:03 +08:00
|
|
|
auto accessor = set.access();
|
|
|
|
|
|
|
|
cout << std::boolalpha;
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
cout << "added non-existing 1? (true) " << accessor.insert(1).second
|
|
|
|
<< endl;
|
2016-07-02 05:05:03 +08:00
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
cout << "added already existing 1? (false) " << accessor.insert(1).second
|
|
|
|
<< endl;
|
2016-07-02 05:05:03 +08:00
|
|
|
|
|
|
|
accessor.insert(2);
|
|
|
|
print_skiplist(accessor);
|
|
|
|
|
|
|
|
cout << "item 3 doesn't exist? (true) "
|
|
|
|
<< (accessor.find(3) == accessor.end()) << endl;
|
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
cout << "item 3 exists? (false) " << accessor.contains(3) << endl;
|
2016-07-02 05:05:03 +08:00
|
|
|
|
2016-08-18 23:03:05 +08:00
|
|
|
cout << "item 2 exists? (true) " << (accessor.find(2) != accessor.end())
|
|
|
|
<< endl;
|
2016-07-02 05:05:03 +08:00
|
|
|
|
|
|
|
cout << "at item 2 is? 2 " << *accessor.find(2) << endl;
|
|
|
|
|
|
|
|
cout << "removed existing 1? (true) " << accessor.remove(1) << endl;
|
|
|
|
cout << "removed non-existing 3? (false) " << accessor.remove(3) << endl;
|
|
|
|
|
|
|
|
accessor.insert(1);
|
|
|
|
accessor.insert(4);
|
|
|
|
|
|
|
|
print_skiplist(accessor);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|