serenity/AK/IDAllocator.h
Andreas Kling 1da31ce8ae LibCore: IDAllocator should never vend ID 0
This was tripping up CObject which interprets timer ID 0 as "no timer".
Once we got ID 0 assigned, it was impossible to turn it off and it
would fire on every event loop iteration, causing CPU churn.
2020-01-05 15:13:55 +01:00

40 lines
794 B
C++

#pragma once
#include <stdlib.h>
#include <AK/HashTable.h>
namespace AK {
class IDAllocator {
public:
IDAllocator() {}
~IDAllocator() {}
int allocate()
{
int r = rand();
for (int i = 0; i < 100000; ++i) {
int allocated_id = r + i;
// Make sure we never vend ID 0, as some code may interpret that as "no ID"
if (allocated_id == 0)
++allocated_id;
if (!m_allocated_ids.contains(allocated_id)) {
m_allocated_ids.set(allocated_id);
return allocated_id;
}
}
ASSERT_NOT_REACHED();
}
void deallocate(int id)
{
m_allocated_ids.remove(id);
}
private:
HashTable<int> m_allocated_ids;
};
}
using AK::IDAllocator;