當前位置:編程學習大全網 - 網站源碼 - C++ STL 中 remove 和 erase 的區別

C++ STL 中 remove 和 erase 的區別

C++ STL中的remove和erase函數曾經讓我迷惑,同樣都是刪除,兩者有什麽區別呢?

vector中的remove的作用是將等於value的元素放到vector的尾部,但並不減少vector的size

vector中erase的作用是刪除掉某個位置position或壹段區域(begin, end)中的元素,減少其size

list容器中的remove 成員函數,原型是void remove (const value_type& val);

他的作用是刪除list中值與val相同的節點,釋放該節點的資源。

而list容器中的erase成員函數,原型是iterator erase (iterator position);

作用是刪除position位置的節點。這也是與remove不同的地方。

考慮到list::erase是與位置有關,故erase還存在API: iterator erase (iterator first, iterator last);

對於set來說,只有erase API,沒有remove API。 erase 的作用是把符合要求的元素都刪掉。

(1) void erase (iterator position);

(2) size_type erase (const value_type& val);

(3) void erase (iterator first, iterator last);

綜上所述,erase壹般是要釋放資源,真正刪除元素的,

而remove主要用在vector中,用於將不符合要求的元素移到容器尾部,而並不刪除不符合要求的元素。

  • 上一篇:高鐵上的保稅倉護膚品是真的嗎?
  • 下一篇:esp32時鐘頻率在哪裏設置
  • copyright 2024編程學習大全網