草庐IT

dynamic-arrays

全部标签

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

c++ - std::array 聚合初始化需要大量令人困惑的花括号

我有以下代码:enumclassMessageDeliveryMethod{POST_MASTER,BUBBLE,NUM_ENUMERATORS};namespace{usingMapType=std::array,static_cast(MessageDeliveryMethod::NUM_ENUMERATORS)>;MapTypeg_mapping={{{"POST_MASTER",MessageDeliveryMethod::POST_MASTER},{"BUBBLE",MessageDeliveryMethod::BUBBLE},}};}这可以编译,但我不知道为什么。g_map

c++ - 从 boost dynamic_bitset 中提取子集

我需要从给定的boostdynamic_bitset中提取和解码位(idx、idx+1、...idx+n_bits)。我创建了以下解决方案:boost::dynamic_bitsetmybitset(...);//buildmask2^{idx+n_bits}-2^{idx}constboost::dynamic_bitsetmask(mybitset.size(),(1>idx).to_ulong();它运行良好,但由于这段代码对我的应用程序的性能至关重要,我很好奇是否有更好的方法来实现这一目标? 最佳答案 解决方法很简单:#in

c++ - dynamic_cast vs static_cast 无效*

在下面程序的最后两行中,static_cast和dynamic_cast表现不同。据我了解,dynamic_cast的结果始终解析为完整对象的地址。所以它以某种方式使用了RTTI。谁能解释一下编译器如何使用RTTI来区分两者。#includeusingnamespacestd;classTop{protected:intx;public:Top(intn){x=n;}virtual~Top(){}friendostream&operator(&b)(&b);cout(p)(p)可能的输出:https://ideone.com/WoX5DI281,2,3,40xbfcce60410xbf

c++ - 是否有标准名称(模板或宏)来替换 ARRAY_SIZE、_countof 等?

我不是在谈论std::array或任何东西,只是经典的VanillaC/C++数组。我知道可以实现ARRAY_SIZE/_countof的各种方式,我只是想知道他们是否已经设法为此标准化了一个名称(在std::我假设)。如果没有,是否有相关建议? 最佳答案 当前的解决方法std::extent-数组的大小如果您正在使用native数组,您可以使用std::extent来自,用于生成数组的Nth维(默认为第一个)中的元素数。inta1[1024];inta2[std::extent::value];//int[1024]一点间接(通用

启动项目报错:The bean ‘XXXXMapper‘ could not be injected because it is a JDK dynamic proxy

Description:Thebean'studentMapper'couldnotbeinjectedbecauseitisaJDKdynamicproxyThebeanisoftype'com.sun.proxy.$Proxy250'andimplements:   com.xinwei.learning.mapper.StudentMapperExpectedabeanoftype'com.xinwei.learning.manager.education.mapper.TeachingClassStudentMapper'whichimplements:   com.xinwei.co

c++ - 当编译器看不到可以完成转换的可能类型时,是否允许编译器优化 volatile 指针的 dynamic_cast?

看看这个小片段:structA{virtual~A(){}};structB{};boolfn(){A*volatilea=newA;returndynamic_cast(a);}是否允许编译器完全删除dynamic_cast,并将dynamic_cast转换为简单的nullptr;?这个问题的原因是这个answer.注意事项:假定volatile意味着编译器不能假定任何有关a的信息,因为它是易变的。这是一个question为什么。dynamic_cast可能不允许被删除的事实是程序中某处可能有一个类型,它派生自A和B。 最佳答案