草庐IT

copy_helper_block

全部标签

java - 限制 try block 范围。有关系吗?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Shouldjavatryblocksbescopedastightlyaspossible?保持较小的tryblock大小是否有任何性能优势(特别是在C++或Java中)[除了它可以为读者提供更多关于哪个语句可以抛出的信息]。鉴于以下方法,我不想抛出该方法。voidfunction()throwsException{statement1statement2statement3//canthrowstatement4statement5}这样做更好吗:选项1voidfunction(){try{stateme

c++ - 函数 try block 处理程序是什么?

我最近遇到了这个问题-什么是函数tryblock处理程序?还有,它有什么用处? 最佳答案 Here你可以找到一个很好的解释。它在构造函数的初始化列表中可能很有用:structA{private:std::strings;public:A(intvalue)try:s(boost::lexical_cast(value)){}catch(boost::bad_lexical_cast){/*handlelexical_castexceptionhere*/}}; 关于c++-函数trybl

c++ - 为什么 std::copy 或 std::swap 不需要 <algorithm>?

根据这个cplusplus.com页,std::copy在header,原样std::swap然而这有效:#include//std::cout#include//std::vector#include//std::ostream_iterator()#include//rand(),srand()//NOTincludingintmain(){srand(time(NULL));constintSIZE=10;std::vectorvec;for(inti=0;i(std::cout,""));std::cout我唯一能想到的是它们是由导出的也...但是为什么我们需要标题吗?

c++ - std::current_exception 是否应该从类的析构函数中的 catch block 返回非空

我和我的同事认为我们在VisualC++2012和2013中发现了一个错误,但我们不确定。以下代码中对std::current_exception的调用是否应该返回一个非空的exception_ptr?似乎在我们尝试过的大多数其他编译器上:#include#include#includeclassA{public:~A(){try{throwstd::runtime_error("ohno");}catch(std::exception&){std::clog在VisualC++下运行时,我们得到“0”(假,这意味着返回的exception_ptr为空)。其他编译器,例如g++,打印“

c++ - 使用 std::copy 从 ifstream 读取十六进制值序列

考虑一个包含以十六进制表示法表示的整数序列的文件。我可以像这样流式传输它们:usingnamespacestd;ifstreaminfile(fname);unsignedinti;vectorvals;while(infile>>std::hex>>i){vals.push_back(i);}如果我想用istream_iterator做同样的事情怎么办?///borksonhex:copy(istream_iterator(infile),istream_iterator(),back_inserter(ref_data));有没有办法告诉istream_iterator如何采用十六

c++ - 使用 `std::copy()` 和 `std::back_inserter()`

我有两个A类和B类都有如下成员:classA{...std::vector>>grid;}classB{...std::vector>>grid;}我发现当我使用std::copy()从A::grid复制到B::grid时,它会失败。这是我所做的://HereisinB'sconstructor.//IinitializeB::gridwiththesamesizeofA::gridgrid=vector>>(GetSetting().grid_cols());for(inti=0;i>(GetSetting().grid_rows());for(intj=0;j但如果我删除初始化部分

c++ - std::copy_n 不改变目标 vector 大小

如果我为vector保留一些空间,然后使用std::copy_n()在其中复制一些值,我会正确复制并访问这些值,但是vector的大小仍然为零。这是预期的行为吗?我是否应该改为调整vector的大小,即使它效率不高?#include#include#includeintmain(){std::vectorsrc,dest;for(doublex=0.0;x测试的编译器:clang、gcc、VisualC++ 最佳答案 butthesizeofthevectorisstillzerostd::copy_n不会改变容器的大小,只是复制值

c++ - 转换为 JPEG 时损坏的 HEIC 图 block

我在将.HEIC图像转换为jpeg时遇到问题。.HEIC文件是用运行最新ios公测版的iphone拍摄的图像。我正在使用librarynokiaprovided解析文件并从.HEIC文件中提取图像block,将它们转换为jpeg并使用ffmpeg/montage将它们粘合在一起。有太多代码无法将其全部粘贴到这个问题中,所以我将所有代码都放在这个githubrepo中.它非常不言自明,只需几个依赖项就可以运行。它们在repo的README中有解释。顺便说一下,这一切都是在osx上完成的。.HEIC文件包含一个8x6的图像网格(图block),如果将它们放在一起,您将获得完整的图像。简单地

c++ - 复制初始化: why move or copy constructor was not called even if copy-elision is turned off?

我的问题不同,因为我可能“知道”复制省略。我正在学习复制初始化。但是,以下代码让我感到困惑,因为我已经使用-fno-elide-contructors-O0选项关闭了复制省略。#includeusingnamespacestd;classtest{public:test(inta_,intb_):a{a_},b{b_}{}test(consttest&other){cout我首先使用命令构建:g++-std=c++11-fno-elide-constructors-O0main.cpp-omain得到如下结果:**showelideconstructors**moveconstruct

c++ - 丢失的一元 std::copy 的最佳实现

C++11引入了语义以避免不必要的对象复制,std::move引入了语义,否则会发生复制。但是,现在也有一些情况需要拷贝,但默认情况下不需要。例如,考虑一下reverse的这种简单实现。因为基于范围的for使用完美转发,所以在循环内修改容器相当于损坏。autoout_iter=container.rbegin();for(autovalue:container){*out_iter++=value;}目标是使用解决这个问题for(autovalue:copy(container)){这看起来很简单……接受任何参数,获取底层类型并返回一个临时拷贝。 最佳答案