草庐IT

BEGIN_ARRAY

全部标签

c++ - 使用 std::prev(vector.begin()) 或 std::next(vector.begin(), -1) 像 some_container.rend() 作为反向哨兵是否安全?

我写了一些采用迭代器但必须以相反顺序进行比较的代码,templateboolfunc(ConstBiIterseq_begin,ConstBiIterseq_end){ConstBiIterlast=std::prev(seq_end);while(--last!=std::prev(seq_begin))//-->Ineedtocomparethebeginningdata{......}returntrue;}在VS2013中,在Debug模式下运行时,--last!=std::prev(seq_begin)将导致调试器断言失败并显示错误消息Expression:stringite

c++ - 减少 begin() 迭代器然后再次增加它

这样的陈述是否符合标准?std::stringstr{"123"};autoit=str.begin();--it;++it;//Does*itpointtocharacter'1'now?我已经在g++4.7.2和clang++3.5上试过了-*it返回'1'。这是C++11中的标准行为吗? 最佳答案 不,这是无效的。这是未定义的行为,因为24.2.6[bidirectional.iterators]指出--it的后置条件是结果必须是可取消引用的。由于它在您的示例中指向begin()之前,因此不满足此条件,因此该代码是非法的。由于

c++ - 将 boost::array<char> 复制到 std::string

我正在尝试cvopyboost::array至std::string.boost::array_buffer;std::stringdata;std::copy(_buffer.begin(),_buffer.begin()+bytes_transferred,data.begin());这是行不通的。所以我稍微改变了一下。char_buffer[1024];std::stringdata;std::copy(_buffer,_buffer+bytes_transferred,data.begin());第二个也不起作用。 最佳答案

c++ - std::array<T, ?> 类型的成员变量

如何为类型为std::array的模板类AClass声明和设置成员变量?(尺寸未定义)?实际std::array是在构造函数中创建的,其中数组的大小是构造函数的参数。在伪C++代码中:templateclassAClass{protected:std::array*array;public:AClass(intn){this->array=newstd::array;}}正确的代码会是什么样子? 最佳答案 不要为此使用std::array,请使用std::vector。std::array的大小必须是编译时常量。如果要在构造函数中传

c++ - C++ 中 "array of unknown bound of T"的外部声明

我使用g++(7.1)和clang++(xcode9.0)和-std=c++11-Wall编译了以下程序并得到了结果:g++0x10052c0500x10052c0400x10052c040clang++0x108b740240x108b740180x108b74018这意味着externinta[];和staticinta[3];声明相同的实体并具有相同的链接(内部链接)。//a.cpp#includeinta[3];voidf(){printf("%p\n",(void*)a);};//b.cppexternvoidf();staticinta[3];voidg(){printf(

c++ - 为什么 boost::multi_array 的 ConstMultiArrayConcept 有一个 NumDims 模板参数?

我写了一个operator处理boost::multi_array的特化,并使用ConstMultiArrayConcept这样它就可以在外部阵列和子阵列上工作。不过,我想知道为什么multi_array概念有一个std::size_tNumDims模板参数,因为它可以简单地从multi_array中提取出来.唯一使用NumDims在ConstMultiArrayConcept作为idgen_helper的递归深度arg,测试切片。作为引用,这里是multi_array的header概念:http://www.boost.org/doc/libs/1_51_0/boost/multi_

c++ - shared_array 的元素作为 shared_ptr?

如果我有一个boost::shared_array(或boost::shared_ptr),有没有办法获得boost::shared_ptr哪个与数组共享?例如,我可能想写:shared_arrayarray(newint[10]);shared_ptrelement=&array[2];我知道我不能使用&array[2],因为它只有类型int*,这对shared_ptr是危险的有一个将采用该类型的隐式构造函数。理想shared_array上面会有一个实例方法,比如:shared_ptrelement=array.shared_ptr_to(2);很遗憾,我找不到这样的东西。share

c++ - 视觉 C++ : forward an array as a pointer

我已经将一些无法在VisualStudio2015上编译的C++11代码缩减为以下我认为应该编译的代码(并且使用clang和gcc):#includevoidtest(constchar*x);intmain(){constcharx[]="Helloworld!";test(std::forward(x));}我知道这里不需要调用forward。这是从一段更复杂的代码中删除的,该代码将可变参数中的任何数组衰减为指针并转发所有内容。我确信可以通过模板特化或SFINAE找到解决此问题的方法,但我想在走那条路之前知道它是否有效的C++。编译器是VisualStudio2015,问题可以重现

C++ Array vs Vector 性能测试解释

很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visitthehelpcenter.9年前关闭。为了量化类似C的数组和C++中Vectors的性能差异,我编写了这个小程序。https://github.com/rajatkhanduja/Benchmarks/blob/master/C%2B%2B/vectorVsArray.cpp为了在共同点上比较它们,我决定测试随机访问和顺序访问。我添加了迭代器,只是为了比较它们(但这不是问题的重点)。对于具有7.7GBRAM且数组/vector大小为1

c++ - constexpr 与 std::array - "Non-type template argument is not a constant expression"

这个问题在这里已经有了答案:Errorusingaconstexprasatemplateparameterwithinthesameclass(2个答案)关闭9年前。我正在尝试实现以下内容:#include#includeclassClass2{};classClass1{public:staticconstexpruint8_tGetMax(){return5;}staticconstexpruint8_tGetMin(){return0;}staticconstexpruint8_tGetCount(){returnGetMax()-GetMin()+1;}private:std