我正在研究/玩分配器试图理解它是如何工作的。但是我在尝试实现接受分配器的普通容器时遇到了问题。现在我最终得到了这个:
template<class T, class Allocator =std::allocator<T>> class Container {
public:
using allocator_type = Allocator;
using value_type = T;
using pointer = typename std::allocator_traits<allocator_type>::pointer;
using reference = value_type&;
using size_type = std::size_t;
Container( size_type n =0 , const allocator_type& allocator =allocator_type() ){
std::cout << "ctor" << std::endl;
allocator.allocate(n);
};
};
int main(int argc, const char* argv[]){
Container<int> c {5};
return 0;
}
它给我一个错误member function 'allocate' not viable: 'this' argument has type 'const allocator_type' (aka 'const std::__1::allocator<int>'), but function is not marked const
如何修复该错误,好吗?我错过了什么吗? 我打算稍后使用特征,但希望首先使用旧方法使其工作。
答案 0 :(得分:1)
你的行
allocator.allocate(n);
尝试调用allocate
的{{1}}方法,该方法未定义为allocator
方法。但是,如果你看,const
的类型是allocator
,那就是对const allocator_type&
的const引用。
那你怎么用呢?使用const对象(或引用一个)通常可以做的一件事是从中构造一个不同的非const对象。例如,这构建:
allocator_type
正如SergeyA在评论中正确指出的那样,通常不构建临时的临时allocator_type(allocator).allocate(n);
,而是建立这样的成员:
allocator_type