草庐IT

dynamic_bitset

全部标签

c++ - 为什么虚函数调用比 dynamic_cast 快?

我写了一个简单的例子,估计调用虚函数的平均时间,使用基类接口(interface)和dynamic_cast和调用非虚函数。这是它:#include#include#include#include#defineCALL_COUNTER(3000)__forceinlineintsomeFunction(){return5;}structBase{virtualintvirtualCall()=0;virtual~Base(){};};structDerived:publicBase{Derived(){};virtual~Derived(){};virtualintvirtualCal

c++ - 避免 dynamic_cast/RTTI

我最近正在为一个副项目(cpp-markdownlibrary,出于好奇)编写一段C++代码,遇到了一个编码问题,我想听听一些意见。cpp-markdown有一个名为Token的基类,它有许多子类。两个主要的子类是Container(包含其他Token的集合)和TextHolder(用作Token的基类当然是包含文本的)。大部分处理是通过虚函数处理的,但其中一些处理在单个函数中处理效果更好。为此,我最终使用dynamic_cast将指针从Token*向下转换为它的子类之一,这样我就可以调用特定于子类的函数,并且它的子类。转换不可能失败,因为代码能够通过虚函数(例如isUn​​match

c++ - 为什么带有 unsigned long long 参数的 std::bitset 构造函数未标记为显式?

标准库类模板std::bitset有一个构造函数(C++11及更高版本,C++11之前的unsignedlong参数)constexprbitset(unsignedlonglong)noexcept与许多最佳实践指南相反,此单参数构造函数未标记为explicit.这背后的原理是什么? 最佳答案 显式构造主要反对explicit构造函数是无符号整数的复制初始化不再有效constexprautoN=64;std::bitsetb(0xDEADC0DE);//OK,directinitializationstd::bitsetb=0xD

c++ - Q : How bitset are inside?

问题真的很简单(想问),std::bitset与uint32_t相同为了内存?或者它更像是std::array?我通常会这样做:uint32_tindex:20;uint32_tmagic:12;那么它和这段代码一样吗?std::bitsetindex;std::bitsetmagic; 最佳答案 uint32_tindex:20;uint32_tmagic:12;Soit'sthesameasthiscode?std::bitsetindex;std::bitsetmagic;绝对不是,了解其中的区别非常重要。首先,std::bi

c++ - dynamic_cast<>有多快

...大约与典型的std::string::operator==()相比?我在下面提供了更多详细信息,我不确定它们是否有任何相关性。具有复杂性或近似值的答案就足够了。谢谢!详细信息:我将在列表的for循环中使用它来查找一些特定实例。我估计我的平均继承水平为3.5类。我正在寻找的那个有一个父类、一个祖父类和在这两个“接口(interface)”之上,即用几个virtualvoidabc()=0;来抽象类。没有我要查找的子类。 最佳答案 这在很大程度上取决于您的编译器、特定的类层次结构、硬件以及各种因素。您确实需要直接在您的特定应用程序

c++ - 如果与指针一起使用,dynamic_cast 何时会抛出异常?

我在源代码中使用dynamic_cast将指针转换为如下所示,Base*base=herestoringthepointer;Derived*derived=dynamic_cast(base);如果base没有类层次结构的指针,则转换失败并返回NULL。在接下来的几行中,我正在检查NULL。所以没问题。我遇到了故障转储,我的应用程序由于dynamic_cast抛出异常而崩溃。我知道dynamic_cast只有在与引用类型一起使用时才会抛出异常。知道当我在上面的源代码中使用指针时,dynamic_cast会抛出异常吗? 最佳答案 A

c++ - 使用 dynamic_cast 转换 const 类

我想投这个:classBase{public:virtual~Base(){};};classDer:publicBase{};intmain(){constBase*base=newDer;Der*der=dynamic_cast(base);//Errorreturn0;}我该怎么办?我试着输入:constDer*der=dynamic_cast(base);维护常量,但这不起作用。 最佳答案 试试这个:constDer*der=dynamic_cast(base);dynamic_cast无法删除const限定符。您可以使用c

c++ - 错误 : cannot dynamic_cast . ..(目标不是指针或引用)

我正在学习C++中的异常处理并遇到了问题。这是代码:#include#includeusingnamespacestd;classA{public:virtualvoidf(void){}};classAA:publicA{public:voidaa(void){};};intmain(void){Aa;try{dynamic_cast(a).aa();}catch(exceptionex){cout所以我以为trycatch会让函数执行并告诉我异常的内容,但是我的编译器没有编译它。我在GNUGCC中使用代码块。请帮助我并告诉我我需要做什么才能让代码按预期运行。非常感谢。

c++ - DECLARE_DYNAMIC 和 DECLARE_DYNCREATE 之间的区别?

你能告诉我DECLARE_DYNAMIC和DECLARE_DYNCREATE有什么区别吗?我们究竟可以在哪里使用它们? 最佳答案 第一个声明类具有运行时类型信息,第二个声明可以在运行时动态创建实例。这在MSDN文档中有详细描述-请参阅Run-TimeObjectModelServices等链接了解更多信息。 关于c++-DECLARE_DYNAMIC和DECLARE_DYNCREATE之间的区别?,我们在StackOverflow上找到一个类似的问题: htt

c++ - dynamic_cast 困惑

我放弃了这个...$5.2.7/2-"IfTisapointertype,vshallbeanrvalueofapointertocompleteclasstype,andtheresultisanrvalueoftypeT.IfTisareferencetype,vshallbeanlvalueofacompleteclasstype,andtheresultisanlvalueofthetypereferredtobyT."根据上述,下面的代码应该是合式的。structA{};structB:A{};intmain(){Bb;Aa,&ar1=b;B&rb1=dynamic_cast