草庐IT

C++ move 语义 : why copy assignment operator=(&) is called instead of move assignment operator=(&&)?

我有以下代码:#include#includeusingstd::cout;structSomeType{SomeType(){}SomeType(constSomeType&&other){cout我希望move构造函数调用move赋值运算符。下面是这个程序的输出:SomeType(SomeType&&)operator=(constSomeType&)operator=(SomeType&&)如您所见,move赋值运算符已成功调用,但在move构造函数内分配给*this时未成功调用。为什么会发生这种情况,我能以某种方式解决它吗? 最佳答案

c++ - 返回值优化 : ho can I avoid copy construction of huge STL containers.

当我想要一个函数返回一个容器时:vectorfunc(){vectorresult;...returnresult;}按以下方式使用:vectorresult=func();为了避免复制我的容器的开销我经常编写函数,以便它只返回接受一个容器的非常量实例。voidfunc(vector&result){result.clear();...result;}按以下方式使用:vectorresult;func(result);难道我的努力没有意义,因为我可以确定编译器总是使用返回值优化? 最佳答案 没有意义。你提到的RVO类型称为命名RVO

c++ - std::copy 和 std::vector 问题

我明白为什么这会导致段错误:#include#includeusingnamespacestd;intmain(){vectorv;intiArr[5]={1,2,3,4,5};int*p=iArr;copy(p,p+5,v.begin());return0;}但为什么这不会导致段错误?#include#includeusingnamespacestd;intmain(){vectorv;intiArr[5]={1,2,3,4,5};int*p=iArr;v.reserve(1);copy(p,p+5,v.begin());return0;} 最佳答案

c++ - 使用 std::ifstream、std::istream_iterator 和 std::copy 不读取整个文件

我在一个188字节的文件中使用了以下代码:std::ifstreamis("filename",std::ios::binary);std::vectorbuffer;std::istream_iteratori_input(is);std::copy(i_input,std::istream_iterator(),std::back_inserter(buffer));std::cout但是它只读取了188个字节中的186个字节。我已经在十六进制编辑器和ls-al中确认了文件大小。 最佳答案 我不知道为什么,但默认情况下似乎会跳过

c++ - QFile::copy() 的进度条?

我正在制作一个在Qt中复制文件的程序。我想知道如何将QProgressBar与boolQFile::copy(constQString&fileName,constQString&newName)一起使用。这甚至可以通过copy函数实现吗?可以暂停复制过程吗? 最佳答案 你不能使用静态QFile::copy()方法来做到这一点。正如Maciej所说,您需要编写自己的类(class)。它应该使用两个QFile对象,一个用于读取,一个用于写入。分部分传输数据(例如整个文件大小的1%)并在每个部分后发出进度信号。您可以将此信号连接到进度对

c++ - 为什么 std::is_copy_constructible 的行为不如预期?

#includeintmain(){std::is_constructible_v;//false,asexpected.std::is_copy_constructible_v;//true,NOTasexpected!}根据cppref:IfTisanobjectorreferencetypeandthevariabledefinitionTobj(std::declval()...);iswell-formed,providesthememberconstantvalueequaltotrue.Inallothercases,valueisfalse.std::is_copy_c

c++ - STL 容器 move 语义并按值返回 : how many times of copying get avoided away?

我知道在C++11中,move语义已经在STL容器中实现以避免临时对象。人们说现在编写按值返回的函数是完美的。但我对究竟有多少次复制实际上被避免感到困惑。请看下面的例子:vectormyVector(){vectorres;res.push_back(4);res.push_back(5);returnres;}vectorv=myVector();我的理解是在c++03中,myVector返回res的拷贝(4,5复制了一次),在评估vectorv=myVector();时vector的复制构造函数vector(constvector&)被调用(4,5复制了两次)。但是在具有move语

c++ - 如何在 va_start 中使用字符串?

出于某种原因,我无法正常工作:voidexamplefunctionname(stringstr,...){...va_start(ap,str.c_str());我也没有得到这个工作:voidexamplefunctionname(stringstr,...){...intlen=str.length();char*strlol=newchar[len+1];for(inti=0;i但这确实:voidexamplefunctionname(constchar*str,...){...va_start(ap,str);有人可以告诉我如何使用字符串代替constchar*吗?当我调用ex

C++:接口(interface)强制定义copy-constr

有没有什么方法可以让接口(interface)类强制执行复制构造函数的定义,也许还有其他构造函数的定义?在我的例子中,我有一个IResource纯抽象类,我希望所有实现此接口(interface)的类都定义一个复制构造函数、一个用于从文件加载的构造函数和一个用于从内存加载的构造函数. 最佳答案 为了构造一个对象,您需要知道要使用的具体类(否则它怎么知道要分配多少内存,或者要使用哪个虚拟表,等等?)。因此,在处理构造函数时接口(interface)不起作用,您不能使用接口(interface)(纯虚拟)来强制存在这样的构造函数。当你想

c++ - 为什么我不能直接将 to_lower_copy 传递给 transform 而不是将其包装在 lambda 中?

我正在尝试使用boost::to_lower_copy和std::transform来小写一堆字符串。如下,变体1,使用lamdba工作;变体2还可以证明这是编译器选择的正确模板重载。但是lambda很傻——它所做的只是将单个参数转发给boost::to_lower_copy。但是变体3,直接使用函数模板不会编译,即使我实例化它。我错过了什么?我有clang版本3.3(tags/RELEASE_33/rc3),使用libstdc++-4.8.1-1.fc19.i686和boost-1.53​​.0-14.fc19.i686。vectorstrings={"Foo","Bar"};vec