草庐IT

dynamic_bitset

全部标签

c++ - bitset 操作的推荐做法是什么?

我正在研究机器模拟程序。我有一个用于主内存的位集vector,因此我可以使用指向该vector的指针pMemory->at(i)来访问任何特定的“字”。我真的更喜欢位集vector设计,并且我坚持使用它(这个程序将在...大约6小时内到期,哎呀!)我在尝试弄清楚如何让位集进出不同位置(模拟寄存器和其他内存位置等)时遇到了一些麻烦,所以我阅读了一些关于使用流的内容。我想出了这个:#include#include#include#includeusingnamespacestd;intmain(){/**demonstratinguseofstringstreamto/frombitset

c++ - dynamic_cast 中的模糊转换

考虑获取对象作为参数并打印其类型的问题:#includeclassA{};classB:publicA{};classC:publicA{};classD:publicC,publicB{};usingnamespacestd;templatevoidprint_type(T*info){if(dynamic_cast(info))cout(info))cout(info))cout(info))cout它给我以下错误:“从派生类‘D’到基类的转换不明确。”但是我没看出歧义在哪里:如果main(d)中声明的对象是D类型,为什么不能直接转换为A类型呢?此外,如果我传递一个字符串类型的参数

c++ - 将 dynamic_cast 与模板一起使用

在用C++实现基于模板的工厂时,我创建了以下allocator函数来实例化给定的子类:templateParentClass*allocator(){ChildClass*child=newChildClass();ParentClass*parent=dynamic_cast(child);if(NULL==parent){deletechild;returnNULL;}returnparent;}一切正常,但是当通过静态代码分析工具(如coverity)运行代码时,deletechild;行被标记为逻辑死代码。我进行运行时检查的原因是为了断言,ChildClass是从ParentC

c++ - 如何序列化 boost::dynamic_bitset?

如何使用boost::dynamic_bitset成员序列化一个类?#include#include#include#include#includeclassA{friendclassboost::serialization::access;boost::dynamic_bitsetx;templatevoidserialize(Archive&ar,constunsignedint){ar&x;}};intmain(){Aa;std::stringstreamss;boost::archive::text_oarchiveoa(ss);oa编译报错(boost1.57)Infilei

c++ - 为什么 std::bitset<8> 是 4 个字节大?

似乎对于std::bitset,大小设置为4个字节。对于33到64的大小,它直接跳到8个字节。不会有任何开销,因为std::bitset是偶数4个字节。我可以看到在处理位时对齐到字节长度,但为什么位集需要对齐到字长,尤其是对于最有可能在内存预算紧张的情况下使用的容器?这是在VS2010下。 最佳答案 最可能的解释是bitset使用整数个机器字来存储数组。这可能是出于内存带宽的原因:读/写在字边界对齐的字通常相对便宜。另一方面,读取(尤其是写入!)任意对齐的字节在某些架构上可能代价高昂。由于我们讨论的是每个bitset几个字节的固定大

c++ - bitset 是否保证连续性?

快速而简单的问题:std::bitset是否保证在内存中是连续的?我知道它遵守CopyConstructible和CopyAssignable概念,但它是否也是像std::vector这样的ContiguousContainer(或类似的东西)?除了填充之外,我还想对这样的结构进行按位运算:structtmp{std::bitsetb;unsignedintc;};所以b的连续性是相当重要的。当然,这会导致知道std::bitset是否是标准布局类,以便每个按位运算都有效。 最佳答案 标准中对std::bitset没有要求具有任何特

c++ - 是否可以使用 dynamic_cast 进行模板类型检查?

templatevoidcheckObject(TgenericObject){MyClassA*a=dynamic_cast(genericObject);if(a!=NULL){//weknowitisoftypeMyClassA}MyClassB*b=dynamic_cast(genericObject);if(b!=NULL){//weknowitisoftypeMyClassB}}这样的事情可能吗?我们有一个模板类型,但我们想知道它是实际类型吗? 最佳答案 在模板世界中,您可能只想为每种类型专门化模板,而不是进行运行时检查

c++ - 这个 bitset::count() 的实现是如何工作的?

下面是std::bitset::count与MSVC2010的实现:size_tcount()const{//countnumberofsetbitsstaticchar_Bitsperhex[]="\0\1\1\2\1\2\2\3\1\2\2\3\2\3\3\4";size_t_Val=0;for(int_Wpos=_Words;0>=4)_Val+=_Bitsperhex[_Wordval&0xF];return(_Val);}有人可以向我解释这是如何工作的吗?_Bitsperhex有什么诀窍? 最佳答案 _Bitsperhex

c++ - 为什么我在使用 dynamic_cast 和模板时收到错误 "A is an inaccessible base of B"?

为什么对f的调用没有解析为第一个函数重载?我收到错误:source.cpp:Infunction'intmain()':source.cpp:12:31:error:'A'isaninaccessiblebaseof'B'classA{};classB:A{};voidf(constA&){std::coutvoidf(T){std::cout(b));}请注意,如果我取出dynamic_cast,代码将起作用,但secondf被调用(它打印“Generic”)。但我想做的是接到第一个电话。我认为dynamic_cast会起作用,但由于某种原因它会导致问题。我在这里做错了什么?

c++ - 使用 dynamic_pointer_cast 时无法动态转换

为什么这段代码不起作用?std::shared_ptre=ep->pop();std::shared_ptrt;t=std::dynamic_pointer_cast(e);我收到以下错误:/usr/include/c++/4.6/bits/shared_ptr.h:386:error:cannotdynamic_cast'(&__r)->std::shared_ptr::.std::__shared_ptr::get[with_Tp=Event,__gnu_cxx::_Lock_policy_Lp=(__gnu_cxx::_Lock_policy)2u]()'(oftype'clas