emplace

简介: emplace
class Test
{
public:
  Test(int) { cout << "Test(int)" << endl; }
  Test(int, int) { cout << "Test(int, int)" << endl; }
  Test(const Test&) { cout << "Test(const Test&)" << endl; }
  Test(Test &&) { cout << "Test(Test &&)" << endl; }
  ~Test() { cout << "~Test()" << endl; }
};
//容器的空间配置器
template<typename T>
class MyAllocator
{
  //allocate deallocate
  //construct destory
  T* allocate(size_t size)
  {
    return (T*)malloc(size * sizeof(T));
  }
  template<typename... Types>
  void construct(T* ptr, Types&&... args)
  {
    //args只是一个参数,而且是个Test对象,T也是Test类型
    new (ptr) T(std::forward<Types>(args)...);
  }
};
template<typename T, typename Alloc = MyAllocator<T>>
class vector
{
public:
  vector() : vec_(nullptr), size_(0), idx_(0) {}
  //预留内存空间
  void reserve(size_t size)
  {
    vec_ = allocator_.allocate(size);
    size_ = size;
  }
  void push_back(const T& val)
  {
    allocator_.construct(vec_ + idx_, val);
    idx_++;
  }
  void push_back(T&& val)
  {
    allocator_.construct(vec_ + idx_, std::move(val));
    idx_++;
  }
  //1.引用折叠
  template<typename... Types>
  void emplace_back(Types&&... args)
  {
    //不管是左值引用、右值引用变量,它本身是个左值。传递的过程中
    //要保持args的引用类型(左值的?右值的)类型完美转发forward
    allocator_.construct(vec_ + idx_, std::forward<Types>(args)...);
    idx_++;
  }
private:
  T* vec_;
  int size_;
  int idx_;
  Alloc allocator_;
};
int main()
{
  vector<Test> v;
  v.reserve(100);
  Test t1(10);
  cout << "============" << endl;
  //直接插入对象,两个没有区别
  v.push_back(t1);
  v.emplace_back(t1);
  cout << "============" << endl;
  v.push_back(Test(20));
  v.emplace_back(Test(20));
  cout << "============" << endl;
  v.push_back(20);
  //v.push_back(30, 40);
  cout << "============" << endl;
  //给emplace传入Test对象构造所需要的参数,直接在容器底层构造对象即可
  v.emplace_back(20);
  v.emplace_back(30, 40);
  cout << "============" << endl;
  return 0;
}
相关文章
|
6月前
|
存储 算法 测试技术
C++:Vector的使用
C++:Vector的使用
|
1月前
|
存储 编译器 C++
C++之打造my vector篇(上)
C++之打造my vector篇(上)
27 0
|
3月前
|
安全 Java
Vector的使用
Vector的使用
19 2
|
4月前
|
存储 C语言 C++
【C++】vector的使用上
**C++ STL的vector简介与用法:** Vector是动态顺序数组,提供高效下标访问,支持动态增长。与数组类似但可自动调整大小。常用构造函数包括默认、填充、迭代器范围和拷贝构造。析构函数自动释放内存。赋值运算符执行深拷贝。迭代器接口包括`begin()`和`end()`(反向对应`rbegin()`和`rend()`),C++11增加了const版本以支持只读访问。示例代码展示了不同构造函数和迭代器的使用。
|
容器
push_back还是emplace_back?
emplace_back() 是 C++11 之后,vector容器中添加的新方法,和 push_back()一样,都是在容器末尾添加一个新的元素,相对于push_back函数,它减少了一次类的构造。不同的是emplace_back() 在效率上相比较于 push_back() 有了一定的提升。
【C++】vector的使用 以及 迭代器失效问题
【C++】vector的使用 以及 迭代器失效问题
|
编译器
|
机器学习/深度学习 C++
C++ 中的 std::next_permutation 和 prev_permutation
它用于将范围 [first, last) 中的元素重新排列为下一个字典序更大的排列。一个排列是 N! 元素可以采用的可能排列(其中 N 是范围内的元素数)。不同的排列可以根据它们在字典上相互比较的方式进行排序。代码的复杂度为 O(n*n!),其中还包括打印所有排列。
106 0
|
存储 Linux C++
【C++】vector的介绍和使用(上)
【C++】vector的介绍和使用(上)
【C++】vector的介绍和使用(上)
C++ Vector 使用详解
C++ Vector 使用详解
120 0