如果有了pop_front,pop_back这个功能则很容易造成内存碎片,pop_front会造成头部内存产生碎片,pop_back朝臣尾部内存产生碎片,所以不能像deque(双向迭代器)那样有pop_front, pop_back这样的完全相同的实现.其次才是性能上的问题,vector实现pop_front的功能可以这样:...
vector类主要用的是向量,访问其中的元素可以用下标,比如a[89]而push_front方法和pop_front方法是堆栈中使用的 堆栈用的是指针 用这些操作访问很方便
对vector进行push_front会造成所有元素的迁移,不符合vector设计的初衷
vector<int> vi;vi.push_back(1);vi.push_back(2);vi.push_back(3);vi.erase(vi.begin());//等同于push_front但是,这样实现的实质是,重新开辟内存放置元素后释放原先的内存,这样做的原因是放置内存碎片,在程序中,如果产生内存碎片则意味着这是内存泄露,是十分危险的一件事情,所以不能在stl中...