草庐IT

btn_swap

全部标签

c++ - "using std::swap"如何启用ADL?

在Whatisthecopy-and-swapidiom示例如下:friendvoidswap(dumb_array&first,dumb_array&second)//nothrow{//enableADL(notnecessaryinourcase,butgoodpractice)usingstd::swap;//byswappingthemembersoftwoclasses,//thetwoclassesareeffectivelyswappedswap(first.mSize,second.mSize);swap(first.mArray,second.mArray);}us

c++ - "using std::swap"如何启用ADL?

在Whatisthecopy-and-swapidiom示例如下:friendvoidswap(dumb_array&first,dumb_array&second)//nothrow{//enableADL(notnecessaryinourcase,butgoodpractice)usingstd::swap;//byswappingthemembersoftwoclasses,//thetwoclassesareeffectivelyswappedswap(first.mSize,second.mSize);swap(first.mArray,second.mArray);}us

c++ - swap() 会导致未定义的行为吗?

我试图从[C++11:utility.swap]中了解std::swap的条件。模板定义为templatevoidswap(T&,T&)(加上一些noexcept细节)并具有“交换存储在两个位置的值”的效果。以下程序是否定义明确?#includeintmain(){intm,n;std::swap(m,n);}如果我自己编写交换代码(即inttmp=m;m=n;n=tmp;),它将具有未定义的行为,因为它会尝试左值到右值的转换一个未初始化的对象。但是标准的std::swap函数似乎没有附加任何条件,也不能从规范中得出存在任何左值到右值和因此UB的规范。标准是否要求std::swap对未

c++ - swap() 会导致未定义的行为吗?

我试图从[C++11:utility.swap]中了解std::swap的条件。模板定义为templatevoidswap(T&,T&)(加上一些noexcept细节)并具有“交换存储在两个位置的值”的效果。以下程序是否定义明确?#includeintmain(){intm,n;std::swap(m,n);}如果我自己编写交换代码(即inttmp=m;m=n;n=tmp;),它将具有未定义的行为,因为它会尝试左值到右值的转换一个未初始化的对象。但是标准的std::swap函数似乎没有附加任何条件,也不能从规范中得出存在任何左值到右值和因此UB的规范。标准是否要求std::swap对未

c++ - 如何在具有 copy-and-swap 习语的赋值运算符中使用 noexcept?

移动赋值运算符通常应该声明为noexcept(即将类型存储在STL容器中)。但是copy-and-swap习惯用法允许在单个代码中定义复制和移动赋值运算符。在这种情况下如何处理noexcept说明符?复制构造可以抛出,但我怀疑它是否会违反noexcept说明符。//IsitcorrectconsideringthatTcopyconstructorcanthrow?T&operator=(Tother)noexcept; 最佳答案 由于拷贝是在调用的调用者的方面制作的,因此它不是您的函数所做的一部分。因此它不能由您的函数控制,因此您

c++ - 如何在具有 copy-and-swap 习语的赋值运算符中使用 noexcept?

移动赋值运算符通常应该声明为noexcept(即将类型存储在STL容器中)。但是copy-and-swap习惯用法允许在单个代码中定义复制和移动赋值运算符。在这种情况下如何处理noexcept说明符?复制构造可以抛出,但我怀疑它是否会违反noexcept说明符。//IsitcorrectconsideringthatTcopyconstructorcanthrow?T&operator=(Tother)noexcept; 最佳答案 由于拷贝是在调用的调用者的方面制作的,因此它不是您的函数所做的一部分。因此它不能由您的函数控制,因此您

c++ - 为什么将 std::swap 移至 <utility>?

为什么有std::swap已移至C++11的header?N3290C.2.7说:17.6.3.2Effectonoriginalfeature:FunctionswapmovedtoadifferentheaderRationale:Removedependencyonforswap.Effectonoriginalfeature:ValidC++2003codethathasbeencompiledexpectingswaptobeinmayhavetoinsteadinclude.我无法理解粗体部分。讨论了什么样的依赖,为什么? 最佳答案

c++ - 为什么将 std::swap 移至 <utility>?

为什么有std::swap已移至C++11的header?N3290C.2.7说:17.6.3.2Effectonoriginalfeature:FunctionswapmovedtoadifferentheaderRationale:Removedependencyonforswap.Effectonoriginalfeature:ValidC++2003codethathasbeencompiledexpectingswaptobeinmayhavetoinsteadinclude.我无法理解粗体部分。讨论了什么样的依赖,为什么? 最佳答案

c++ - copy-and-swap 总是最好的解决方案吗?

我看过copy-and-swapvarious中推荐的成语places作为为赋值运算符实现强异常安全性的推荐/最佳/唯一方法。在我看来,这种方法也有缺点。考虑以下使用copy-and-swap的简化类vector类:classIntVec{size_tsize;int*vec;public:IntVec():size(0),vec(0){}IntVec(IntVecconst&other):size(other.size),vec(size?newint[size]:0){std::copy(other.vec,other.vec+size,vec);}voidswap(IntVec&

c++ - copy-and-swap 总是最好的解决方案吗?

我看过copy-and-swapvarious中推荐的成语places作为为赋值运算符实现强异常安全性的推荐/最佳/唯一方法。在我看来,这种方法也有缺点。考虑以下使用copy-and-swap的简化类vector类:classIntVec{size_tsize;int*vec;public:IntVec():size(0),vec(0){}IntVec(IntVecconst&other):size(other.size),vec(size?newint[size]:0){std::copy(other.vec,other.vec+size,vec);}voidswap(IntVec&