8216426: Usage of array placement new may lead to memory corruption
Reviewed-by: rehn, kbarrett, rkennke, eosterlund
This commit is contained in:
parent
744d6085b4
commit
b2f82b3bd3
@ -73,7 +73,7 @@ class ConcurrentHashTable : public CHeapObj<F> {
|
|||||||
void print_value_on(outputStream* st) const {};
|
void print_value_on(outputStream* st) const {};
|
||||||
};
|
};
|
||||||
|
|
||||||
// Only constructed with placement new[] from an array allocated with MEMFLAGS
|
// Only constructed with placement new from an array allocated with MEMFLAGS
|
||||||
// of InternalTable.
|
// of InternalTable.
|
||||||
class Bucket {
|
class Bucket {
|
||||||
private:
|
private:
|
||||||
|
@ -193,8 +193,12 @@ inline ConcurrentHashTable<VALUE, CONFIG, F>::
|
|||||||
{
|
{
|
||||||
assert(_log2_size >= SIZE_SMALL_LOG2 && _log2_size <= SIZE_BIG_LOG2,
|
assert(_log2_size >= SIZE_SMALL_LOG2 && _log2_size <= SIZE_BIG_LOG2,
|
||||||
"Bad size");
|
"Bad size");
|
||||||
void* memory = NEW_C_HEAP_ARRAY(Bucket, _size, F);
|
_buckets = NEW_C_HEAP_ARRAY(Bucket, _size, F);
|
||||||
_buckets = new (memory) Bucket[_size];
|
// Use placement new for each element instead of new[] which could use more
|
||||||
|
// memory than allocated.
|
||||||
|
for (size_t i = 0; i < _size; ++i) {
|
||||||
|
new (_buckets + i) Bucket();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename VALUE, typename CONFIG, MEMFLAGS F>
|
template <typename VALUE, typename CONFIG, MEMFLAGS F>
|
||||||
|
Loading…
Reference in New Issue
Block a user