草庐IT

possible_copy

全部标签

c++ - 'Guaranteed Copy Elision' (P0135, C++1z) 是否可能需要 ABI 损坏?

http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/p0135r0.html2016年6月在芬兰奥卢举行的session上,上述关于“保证复制省略”的提案被投票纳入C++工作文件,然后被投票作为委员会草案发布。希望这会导致明年作为C++17标准发布。该提案阐明了涉及临时对象的各种值类别,以强制在某些用例中不调用复制构造函数。我的问题是“这个新要求可能会破坏以前在这些情况下可能没有进行复制省略的编译器的ABI兼容性,或者以与新要求不兼容的方式实现它?"我正在考虑诸如初始化之类的事情,当对象的创建可以内联时会省略拷贝,但在跨越编译

LeetCode 1079. Letter Tile Possibilities【哈希表,回溯,动态规划,排列组合】中等

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库:https://github.com/memcpy0/LeetCode-Conquest。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目

c++ - 即使 move-assignment 是 noexcept,std::move_if_noexcept 也会调用 copy-assignment;为什么?

我试图尽可能接近强异常保证,但是在玩弄std::move_if_noexcept时,我遇到了一些看似奇怪的行为。尽管下面的类中的移动赋值操作符被标记为noexcept,复制赋值操作符在被调用时被调用带有相关函数的返回值。structA{A(){/*...*/}A(Aconst&){/*...*/}A&operator=(Aconst&)noexcept{log("copy-assign");return*this;}A&operator=(A&&)noexcept{log("move-assign");return*this;}staticvoidlog(charconst*msg){

c++ - 即使 move-assignment 是 noexcept,std::move_if_noexcept 也会调用 copy-assignment;为什么?

我试图尽可能接近强异常保证,但是在玩弄std::move_if_noexcept时,我遇到了一些看似奇怪的行为。尽管下面的类中的移动赋值操作符被标记为noexcept,复制赋值操作符在被调用时被调用带有相关函数的返回值。structA{A(){/*...*/}A(Aconst&){/*...*/}A&operator=(Aconst&)noexcept{log("copy-assign");return*this;}A&operator=(A&&)noexcept{log("move-assign");return*this;}staticvoidlog(charconst*msg){

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::copy 如何与流迭代器一起工作

通常的STL构造是:vectorcol;copy(istream_iterator(cin),istream_iterator(),back_inserter(col));我们使用istream_iterator从std输入(cin)复制到vector。谁能解释这段代码是如何工作的?我的问题是我不太了解这部分:istream_iterator(cin),istream_iterator() 最佳答案 首先,请注意,在这种情况下,根本不需要使用std::copy。您可以直接从迭代器初始化vector:vectorcol((istrea

c++ - std::copy 如何与流迭代器一起工作

通常的STL构造是:vectorcol;copy(istream_iterator(cin),istream_iterator(),back_inserter(col));我们使用istream_iterator从std输入(cin)复制到vector。谁能解释这段代码是如何工作的?我的问题是我不太了解这部分:istream_iterator(cin),istream_iterator() 最佳答案 首先,请注意,在这种情况下,根本不需要使用std::copy。您可以直接从迭代器初始化vector:vectorcol((istrea

c++ - va_copy -- 移植到 Visual C++?

Apreviousquestion展示了一种打印到字符串的好方法。答案涉及va_copy:std::stringformat(constchar*fmt,...);{va_listap;va_start(ap,fmt);std::stringbuf=vformat(fmt,ap);va_end(ap);returnbuf;}std::stringvformat(constchar*fmt,va_listap){//Allocateabufferonthestackthat'sbigenoughforusalmost//allthetime.size_tsize=1024;charbuf

c++ - va_copy -- 移植到 Visual C++?

Apreviousquestion展示了一种打印到字符串的好方法。答案涉及va_copy:std::stringformat(constchar*fmt,...);{va_listap;va_start(ap,fmt);std::stringbuf=vformat(fmt,ap);va_end(ap);returnbuf;}std::stringvformat(constchar*fmt,va_listap){//Allocateabufferonthestackthat'sbigenoughforusalmost//allthetime.size_tsize=1024;charbuf