草庐IT

make_move_iterator

全部标签

c++ - 如何结合 std::make_shared 和 new(std::nothrow)

C++的new有一个选项可以在分配失败时返回空指针而不是抛出bad_alloc异常。Foo*pf=new(std::nothrow)Foo(1,2,3);(是的,我知道这只会阻止new抛出bad_alloc;它不会阻止Foo的构造函数抛出异常。)如果您想使用共享指针而不是原始指针,您通常应该使用make_shared,因为它可以巧妙地分配控制block。autopf=std::make_shared(1,2,3);make_shared封装了新版本,这使得(?)无法选择nothrow版本。因此,您似乎必须放弃make_shared并明确调用new。std::shared_ptrpf(n

c++ - 如何结合 std::make_shared 和 new(std::nothrow)

C++的new有一个选项可以在分配失败时返回空指针而不是抛出bad_alloc异常。Foo*pf=new(std::nothrow)Foo(1,2,3);(是的,我知道这只会阻止new抛出bad_alloc;它不会阻止Foo的构造函数抛出异常。)如果您想使用共享指针而不是原始指针,您通常应该使用make_shared,因为它可以巧妙地分配控制block。autopf=std::make_shared(1,2,3);make_shared封装了新版本,这使得(?)无法选择nothrow版本。因此,您似乎必须放弃make_shared并明确调用new。std::shared_ptrpf(n

c++ - std::move 已经是 T&& 的变量

在页面Howto:WriteaMoveConstructorMicrosoft有一个关于如何编写移动构造函数的示例。它本质上是这样的:MyClass::MyClass(MyClass&&lhs){*this=std::move(lhs);}我已经尝试过了,这里确实需要std::move,但为什么呢?我认为move所做的唯一一件事就是转换为T&&。但是lhs已经是MyClass&&类型了,不是吗? 最佳答案 Namedrvaluereferencesarelvalues.Unnamedrvaluereferencesarervalue

c++ - std::move 已经是 T&& 的变量

在页面Howto:WriteaMoveConstructorMicrosoft有一个关于如何编写移动构造函数的示例。它本质上是这样的:MyClass::MyClass(MyClass&&lhs){*this=std::move(lhs);}我已经尝试过了,这里确实需要std::move,但为什么呢?我认为move所做的唯一一件事就是转换为T&&。但是lhs已经是MyClass&&类型了,不是吗? 最佳答案 Namedrvaluereferencesarelvalues.Unnamedrvaluereferencesarervalue

c++ - 了解 `std::is_move_constructible`

没有移动构造函数但具有接受constT&参数的复制构造函数的类型,满足std::is_move_constructible。例如,在以下代码中:#includestructT{T(constT&){}//T(T&&)=delete;};intmain(){static_assert(std::is_move_constructible::value,"notmoveconstructible");return0;}T将没有隐式移动构造函数,因为它有一个用户定义的复制构造函数。但是,如果我们取消注释移动构造函数的显式删除,代码将不再编译。为什么是这样?我本来希望显式复制构造函数仍然满足s

c++ - 了解 `std::is_move_constructible`

没有移动构造函数但具有接受constT&参数的复制构造函数的类型,满足std::is_move_constructible。例如,在以下代码中:#includestructT{T(constT&){}//T(T&&)=delete;};intmain(){static_assert(std::is_move_constructible::value,"notmoveconstructible");return0;}T将没有隐式移动构造函数,因为它有一个用户定义的复制构造函数。但是,如果我们取消注释移动构造函数的显式删除,代码将不再编译。为什么是这样?我本来希望显式复制构造函数仍然满足s

c++ - 为什么我需要在 move 构造函数的初始化列表中使用 std::move?

假设我有一个(平凡的)类,它可以move构造和move分配,但不能复制构造或复制分配:classmovable{public:explicitmovable(int){}movable(movable&&){}movable&operator=(movable&&){return*this;}movable(constmovable&)=delete;movable&operator=(constmovable&)=delete;};这很好用:movablem1(movable(17));这当然行不通,因为m1不是右值:movablem2(m1);但是,我可以将m1包装在std::mo

c++ - 为什么我需要在 move 构造函数的初始化列表中使用 std::move?

假设我有一个(平凡的)类,它可以move构造和move分配,但不能复制构造或复制分配:classmovable{public:explicitmovable(int){}movable(movable&&){}movable&operator=(movable&&){return*this;}movable(constmovable&)=delete;movable&operator=(constmovable&)=delete;};这很好用:movablem1(movable(17));这当然行不通,因为m1不是右值:movablem2(m1);但是,我可以将m1包装在std::mo

C++ STL : list with Pointers - Iterator cannot access?

我正在为一个包含我的“对象”对象指针的STL列表而苦苦挣扎。我声明:listobjectlist;并通过以下方式插入:this->objectlist.push_back(newObject(address,value,profit));并尝试像在map和其他中一样进行迭代:list::iteratoriter;iter=this->objectlist.begin();while(iter!=this->objectlist.end()){iter->print();}其中print()是Object类的公共(public)方法;这里有什么问题?我无法通过迭代器访问列表中的对象?

C++ STL : list with Pointers - Iterator cannot access?

我正在为一个包含我的“对象”对象指针的STL列表而苦苦挣扎。我声明:listobjectlist;并通过以下方式插入:this->objectlist.push_back(newObject(address,value,profit));并尝试像在map和其他中一样进行迭代:list::iteratoriter;iter=this->objectlist.begin();while(iter!=this->objectlist.end()){iter->print();}其中print()是Object类的公共(public)方法;这里有什么问题?我无法通过迭代器访问列表中的对象?