C++ map(STL map)刪除元素(erase函數刪除元素)詳解

2020-07-16 10:04:32
map 的成員函數 erase() 可以移除鍵和引數匹配的元素,然後返回所移除元素的個數,例如:
std::map<std::string, size_t> people {{ "Fred", 45}, {"Joan", 33},{"Jill", 22}};
std::string name{"Joan"};
if(people.erase(name))
    std::cout << name << " was removed." << std::endl;
else
    std::cout << name << " was not found" << std::endl;
顯然,map 容器的返回值只可能是 0 或 1,0 表明元素不在容器中。也可以用指向刪除元素的疊代器作為 erase() 的引數。這種情況下,返回的疊代器指向被刪除元素的下一個位置。這個引數必須是容器中的有效迭代器,不能是結束疊代器。如果疊代器引數指向的是容器的最後一個元素,那麼會返回結束疊代器。例如:
auto iter = people.erase(std::begin(people));
if(iter == std::end(people))
    std::cout << "The last element was removed."<< std::endl;
else
    std::cout << "The element preceding " << iter->first << "was removed." << std::endl;
當最後一個元素被移除時,這段程式碼會輸出一條訊息或被移除元素後面元素的鍵。也有更高階版本的 erase(),它可以移除兩個疊代器引數所定義範圍內的元素,例如:
auto iter = people.erase(++std::begin(people), --std::end(people));//Erase all except 1st & last
返回的疊代器指向這段元素中最後一個被刪除的元素。如果想刪除容器中的所有元素,可以呼叫成員函數 clear()。