Home C&C++函数库 c++ 语法 程序源码 Linux C库

std::

multiset::operator=

公众成员函数  <set>
C++98 copy (1)
 multiset& operator= (const multiset& x);

复制容器的内容

将新内容分配给容器,替换其当前内容。


C++98:
将x中的所有元素复制到容器中.
容器保留其当前的分配器,该分配器用于在需要时分配额外的存储空间。

在调用之前保存在容器中的任何元素要么被赋值,要么被销毁。

☲  参数


x
一个相同类型的集合对象(例如,具有相同的模板参数,T, Compare和Alloc)。
il
一个初始化列表对象。编译器将自动从初始化列表声明符构造此类对象。
成员类型value_type是容器中元素的类型,在 multiset中定义为其第一个模板形参(T)的别名。

☉  返回值



*this

☣  示例



// assignment operator with multisets
#include <iostream>
#include <set>

int main ()
{
  int myints[]={ 19,81,36,36,19 };
  std::multiset<int> first (myints,myints+5);   // multiset with 5 ints
  std::multiset<int> second;                    // empty multiset

  second=first;                                 // now second contains the 5 ints
  first=std::multiset<int>();                   // and first is empty

  std::cout << "Size of first: " << first.size() << '\n';
  std::cout << "Size of second: " << second.size() << '\n';
  return 0;
}

输出:
Size of first: 0
Size of second: 5

✥ 复杂度



对于复制赋值(1):线性大小(析构,复制)。
对于move赋值(2):在当前容器大小中线性(析构)。*
对于初始化器列表赋值(3):在大小上达到对数级(析构,移动赋值)——如果il已经排序,则为线性。

*如果分配器没有传递,则会增加分配的复杂性。

☣ 迭代器的有效性



与此容器相关的所有迭代器、引用和指针都会失效。
在move赋值操作中,指向x中元素的迭代器、指针和引用也会失效。

⇄ 数据竞争


访问所有复制的元素。
move赋值(2)修改x。
容器及其所有元素都被修改。

☂ 异常安全性



基本保证:如果抛出异常,则容器处于有效状态。
如果allocator_traits::construct不支持元素构造的适当参数, 或者value_type不是copy assignable(或者为(2)移动赋值的),它将导致未定义的行为。

🍄  另请参阅



multiset::multiset 构建multiset对象(公众成员函数)
multiset::insert 插入元素(公众成员函数)

联系我们 免责声明 关于CandCplus 网站地图