L. *_* F. 5 c++ inheritance memory-management final allocator
分配器要求的cppreference页没有说分配器必须是可继承的,即没有说分配器一定不能是最终的。
但是,在许多库中,分配器是私有继承的,以利用无状态分配器的空基类优化。例如:
template <typename T, typename A = std::allocator<T>>
class Dummy_vector :private A {
// ...
A get_alloc() const
{
return static_cast<A>(*this);
}
// ...
};
Run Code Online (Sandbox Code Playgroud)
如果A是最终的,则该实现会中断。
一个可以分配器是最终的?我错过了什么?还是应该为最终分配器包括特殊代码?
(注意:通过“最终分配器的特殊代码”,我的意思是这样的:
template <
typename T,
typename A = std::allocator<T>,
bool = std::is_final<A>
>
class Dummy_vector :private A {
// version for nonfinal allocators
// ...
A get_alloc() const
{
return static_cast<A>(*this);
}
// ...
};
template <typename T, typename A>
class Dummy_vector<T, A, true> {
// special version for final allocators
};
Run Code Online (Sandbox Code Playgroud)
)
这确实是一个问题。另请参见C++ 标准库缺陷报告 2112。该标准不要求可以派生分配器类型。但是,该标准也没有指定从分配器类型派生的实现。因此,共识似乎是,这被认为是实现的错误,因为没有检查分配器类型是否可以从 xe2x80xa6 派生
\n