BAN: Optimize Vector copy assignment to reduce allocations
If vector contains enough elements, it will now replace old elements instead of clearing and reallocating
This commit is contained in:
parent
6707989cd5
commit
cc6b80a55b
|
@ -138,10 +138,13 @@ namespace BAN
|
|||
template<typename T>
|
||||
Vector<T>& Vector<T>::operator=(const Vector<T>& other)
|
||||
{
|
||||
clear();
|
||||
MUST(ensure_capacity(other.size()));
|
||||
for (size_type i = 0; i < other.size(); i++)
|
||||
for (size_type i = 0; i < BAN::Math::min(size(), other.size()); i++)
|
||||
m_data[i] = other.m_data[i];
|
||||
for (size_type i = size(); i < other.size(); i++)
|
||||
new (m_data + i) T(other[i]);
|
||||
for (size_type i = other.size(); i < size(); i++)
|
||||
m_data[i].~T();
|
||||
m_size = other.m_size;
|
||||
return *this;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue