草庐IT

copy-assignment

全部标签

c++ - 就地 std::copy_if

在我看来,std::copy_if对于过滤容器非常有用:std::vectorvec{1,2,3,4};autoitEnd=std::copy_if(vec.begin(),vec.end(),vec.begin(),[](inti){returni>2;});vec.resize(itEnd-vec.begin());但是,std::copy_if指定输入和输出范围不能重叠。还有其他选择吗? 最佳答案 copy_if主要用于将范围复制到另一个范围/容器,即按照设计,该算法的本质是将满足某些条件的元素复制到另一个(非重叠)范围或新容

c++ - 哪个更好 : a lying copy constructor or a non-standard one?

我有一个包含不可复制句柄的C++类。但是,该类必须有一个复制构造函数。因此,我实现了一个将句柄的所有权转移到新对象的方法(如下所示),classFoo{public:Foo():h_(INVALID_HANDLE_VALUE){};//transferthehandletothenewinstanceFoo(constFoo&other):h_(other.Detach()){};~Foo(){if(INVALID_HANDLE_VALUE!=h_)CloseHandle(h_);};//otherinterestingfunctions...private:///disallowas

c++ - std::array 错误:没有名为 'assign' 的成员

在下面的代码中,编译器报错为:structstd::arrayhasnomembernamed'assign'.Here,这似乎是可能的。为什么会这样?(编译器:g++4.8.2)#includeintmain(){std::arrayarr;arr.assign(4.);//error:hasnomembernamed'assign'return0;} 最佳答案 array::assign()是一个VisualStudio扩展。您正在使用g++进行编译。点这里standardg++array

c++ - Qt 拖放 : cannot move when copy is enabled (Ubuntu Gnome)

我正在实现一个View和一个模型,我希望在其中支持内部移动项目(通过拖动)和复制项目(通过在拖动时按Ctrl)。我已经按照说明完成了我需要做的一切。我已经设置了mime函数,我已经实现了removeRows()和flags()。问题是当我拖动时,它默认为复制操作(我得到带有加号的箭头光标,它确实通过在模型中创建一个新项目来复制项目)。我能看到的唯一区别是:如果我在supportedDropActions()中只返回Qt::MoveAction,它只会移动。如果我返回(Qt::CopyAction|Qt::MoveAction),它只会复制。有什么想法吗?我希望它像Nautilus(Gn

c++ - std::vector::assign 等效于 QVector

我有一个C风格的数组,我想将它分配给一个QVector。如果我使用std::vector,我会使用assign():intarr[]={1,2,3,4,5};std::vectorv;v.assign(arr,arr+sizeof(arr)/sizeof(int));但对于QVector,我找不到类似的assign()方法,或任何接受范围的构造函数。我已经编写了一个for循环来执行此操作,但令我惊讶的是没有这样一个基本函数,真的是这样吗,或者是否有等效的函数? 最佳答案 您可以使用Qt的qCopy():intarr[]={1,2,3

C++ copy_if lambda 捕获 std::string

这是来自此处的后续问题:C++-Developingownversionofstd::count_if?我有以下功能://vectorforstoringthefilenamesthatcontainssoundstd::vectorFilesContainingSound;voidContainsSound(conststd::unique_ptr&s){//OpentheWavfileWavwaveFile=Wav("Samples/"+s->filename_);//Copythesignalthatcontainsthesufficientenergystd::copy_if(

c++ - 为什么我需要另一个迭代器作为 std::copy() 中的参数?

我不明白为什么我需要将另一个迭代器作为调用std::copy()以读取文件的第二个参数。迭代器如何结束文件?vectorv;istream_iteratoris(file),end;copy(is,end,back_inserter(v)); 最佳答案 Howisiterator'end'endingofafile?按照惯例和/或标准库中的设计决定。迭代器end是默认构造的,在cppreference上,我们了解默认的std:istream_iterator构造函数:constexpristream_iterator();Const

c++ - 为什么 insert_or_assign 没有迭代器重载?

问题在C++17中,标准库中的关联容器将具有insert_or_assign成员函数,该函数将执行其名称所暗示的操作。不幸的是,它似乎没有用于批量插入/分配的基于迭代器的接口(interface)。我什至triedtocompile小例子,从编译器错误来看,编译器找不到合适的重载,而且两个候选者都不太接近基于迭代器的接口(interface)。问题为什么C++17不包含基于迭代器的insert_or_assign以进行批量操作?有什么技术原因吗?设计问题?我的假设和想法我看不出有任何技术原因不添加基于迭代器的批量插入/添加。这似乎很可行。它无论如何都需要查找key,所以我没有看到任何违

c++ - 为什么 basic_string::append (iter, iter) 不调用 std::copy?

我刚刚发现在VisualStudioC++2010中,basic_string::append(iter,iter)显然不是通过使用std::copy.第一个问题:现在假设我实现了自己的迭代器类型,并为我的迭代器类型优化了std::copy重载,以便提供更高效的block式复制。除了重载append之外,还有什么方法可以让basic_string::append使用此优化?basic_string::append(iter,iter)是否有可能不进行字符复制?第二个问题(作为我自己实现的起点):以下是否保证有效?std::stringt("JohnB");std::strings;s.

c++ - std::is_assignable 是如何工作的?

这是std::is_assignable的实现,我花了几个小时试图了解它如何静态地找出模板化对象的类型,但没能成功。在标准中is_assignable指出分配的两边都转换为std::add_rvalue_reference::type.我不明白那句话,也不明白std::add_rvalue_reference::type可用于预测对象的类型。谁能给我一个简单的解释,作为我理解std::is_assignable工作原理的第一步? 最佳答案 下面是删除了一些词法混淆的相同代码:1043template1044classis_assig