草庐IT

copy_helper_block

全部标签

c++ - QFile::copy create 会创建文件的拷贝或将内容从一个文件移动到另一个文件吗?

我正在尝试使用C++/Qt将文件从一个位置复制到另一个位置(在设备中)我试过QFile::copy("path1/file","path2");我想将路径1中的文件复制到路径2中。path2没有该文件。我只是想知道这是否是正确的方法,因为上面的代码似乎不起作用。另外,我应该在尝试复制之前打开一个文件吗?需要帮助! 最佳答案 如果你想将path1/file复制到具有相同文件名的path2中,你需要这样做:QFile::copy("path1/file","path2/file");复制允许您更改文件的名称。示例:QFile::copy

c++ - std::copy 用于动态分配的指针

这可能是一个非常新手的问题。我正在处理的类(我们称之为MyClass)包含以下变量intnbins;double*bins;//=newdouble[nbins+i]因为我正在实现一个复制构造函数MyClass(constMyClass&source)我需要复制source.bins。我打算使用algorithm中的std::copy,但我发现的所有示例都展示了如何复制静态数组,如doublebins[]=。..或标准数据结构,如std::vector。我找不到任何示例,其中std::copy用于像double*bins=newdouble[nbins+i]这样的指针。所以,我的问题是

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++ - 以二进制模式从文件中读取 block 到缓冲区并将该缓冲区写入另一个文件

我正在努力实现这样的目标:while(ifstreamhasnotbeenentirelyread){readachunkofdataintoabufferthathassizeBUFLENwritethisbuffertoostream}起初我试图通过使用ifstream.eof()作为我的while条件来实现这一点,但我听说这不是可行的方法。我一直在查看std::ios::ifstream的其他功能,但无法弄清楚还有什么用。PS:我正在使用缓冲区,因为正在传输的文件可能会变得非常大。 最佳答案 iostream类负责所有必要的缓

c++ - 在析构函数中尝试 Catch block

在阅读HurbSutter的“MoreExceptionalC++”时,我偶然发现了以下代码://Example19-5:Alternativerightsolution//T::Close(){//...codethatcouldthrow...}T::~T()/*throw()*/{try{Close();}catch(...){}}我的理解是,这不是一个好主意。因为,如果在堆栈展开期间由于异常调用了T析构函数,然后Close()抛出异常,那么这将导致调用Terminate()。有人可以阐明这一点吗?提前致谢。 最佳答案 Myu

c++ - 代码块注释掉整个 block

我正在使用适用于C++的CodeblocksIDE,我尝试用谷歌搜索它,但找不到答案。如何在Codeblocks中注释掉一段代码?例如在Eclipse中它的ctrl+7。 最佳答案 Ctrl+Shift+C评论选中的blockCtrl+Shift+X取消注释。 关于c++-代码块注释掉整个block,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5288077/

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++ - block 非专用模板 C++

是否有可能以某种方式禁止对未明确编写专门化的类型使用模板化函数。我的意思是类似的东西templatevoidfoo(){}templatevoidfoo(){}intmain(intargc,char*argv[]){foo();//okfoo();//Wrong-nospecializedversionforchar.}我不能跳过函数的通用版本,因为编译器说,当我尝试专门化时,foo不是模板函数。我可以简单地写一些不能在通用函数中编译的东西,并添加一些注释来解释原因,但这将是非常无用的。我想做的是能够直接导致编译器出现“foo()未定义”之类的错误。 最佳

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中确认了文件大小。 最佳答案 我不知道为什么,但默认情况下似乎会跳过