memgraph/benchmark/allocator.cpp

59 lines
1005 B
C++

#include <iostream>
#include <vector>
#include <thread>
#include "utils/memory/allocator.hpp"
#include "utils/memory/maker.hpp"
struct TestStruct
{
TestStruct(int a, int b, int c, int d)
: a(a), b(b), c(c), d(d) {}
int a, b, c, d;
};
void test_classic(int N)
{
TestStruct** xs = new TestStruct*[N];
for(int i = 0; i < N; ++i)
xs[i] = new TestStruct(i, i, i, i);
for(int i = 0; i < N; ++i)
delete xs[i];
delete[] xs;
}
void test_fast(int N)
{
TestStruct** xs = new TestStruct*[N];
for(int i = 0; i < N; ++i)
xs[i] = makeme<TestStruct>(i, i, i, i);
for(int i = 0; i < N; ++i)
delete xs[i];
delete[] xs;
}
int main(void)
{
constexpr int n_threads = 256;
constexpr int N = 80000000 / n_threads;
std::vector<std::thread> threads;
for(int i = 0; i < n_threads; ++i)
threads.push_back(std::thread(test_fast, N));
for(auto& thread : threads){
thread.join();
}
return 0;
}