我有一个结构模板,它采用两种类型(T和S),并且在某些时候使用static_cast从一种类型转换键入另一个。通常情况下,T和S是同一类型。设置的简化示例:templatestructfoo{voidbar(Tval){/*...*/some_other_function(static_cast(val));/*...*/}};在S与T是同一个类的情况下,static_cast是否会引入额外的开销,或者它是否为null哪个操作总是会被忽略?如果它确实引入了开销,是否有一个简单的模板元编程技巧来仅在需要时执行static_cast,或者我是否需要创建部分特化来处理T==S案例?如果可能,
我在C++中有以下情况:抽象基类Abstract1和Abstract2。它们是无关的。类Foo派生自Abstract1和Abstract2我在一个编译单元中,我没有关于类Foo的信息(没有声明,没有定义)。只有Abstract1和Abstract2是已知的。(实际上,Foo甚至定义在一个DLL中)dynamic_cast是否允许从Abstract1*转换为Abstract2*?这是标准吗? 最佳答案 你所描述的是所谓的cross-cast。对于dynamic_cast(v),标准在[expr.dynamic.cast]/8中指定If
为什么是未定义的行为?structs{constintid;//(引用标准会很好)。这个问题来自thisanswer. 最佳答案 显示的代码片段没有任何内在的UB。但是,几乎可以肯定,在任何正常使用情况下,UB都会立即出现。来自[basic.life]/8(强调我的)If,afterthelifetimeofanobjecthasendedandbeforethestoragewhichtheobjectoccupiedisreusedorreleased,anewobjectiscreatedatthestoragelocatio
我开始在C++0X/11中使用智能指针,但遇到了一个特殊情况。我想使用shared_ptr向上转换一个对象的实例。Extend类继承自Base类,其中Base类具有虚拟析构函数以使其具有多态性(否则dynamic_pointer_cast会提示非多态类转换)。如果因此:std::shared_ptrobj=std::make_shared();然后我做:obj=std::dynamic_pointer_cast(obj);安全吗?其他指向该对象的指针会怎样?是否只有obj将其视为Extend,而其他共享指针仍将其视为Base?向上转换同一实例是否安全,还是我应该做其他事情?编辑:感谢您
是否可以根据模板参数的常量性有条件地启用模板类的非const/const数据成员?或者可能有一些条件类型定义?我考虑过将std::enable_if与std::is_const一起使用,但没有我可以使用的std::is_not_const。classA;templateclassTest{A&m_a;//IfT!=const.constA&m_a;//IfT==const.};请注意总是T!=A。 最佳答案 是的,您可以使用std::conditional:templateclassTest{typenamestd::conditi
如何获取一个bool值来指示已知方法是否具有const限定符?例如:structA{voidmethod()const{}};structB{voidmethod(){}};booltestA=method_is_const::value;//ShouldbetruebooltestB=method_is_const::value;//Shouldbefalse在type_traitsheader我找到了一个is_const我可以使用测试,但我需要方法类型,但我不确定如何获取它。我试过:std::is_const::value但它不起作用,我能理解为什么(void(*ptr)()con
我正在使用过时的VisualStudio2008(让我为您省去“这是您的问题”的麻烦。)这似乎是VisualStudio的问题:http://rextester.com/XKFR77690这似乎是assert的问题宏:http://ideone.com/bhxMi0给定这些结构:structbase{virtual~base(){}};templatestructFoo:base{Tfoo;};我能做到:base*test=newFoo>;if(dynamic_cast>*>(test)!=NULL)cout但是当我使用与if中完全相同的代码时-assert中的声明:assert(dy
如果我在std::string变量上使用std::reverse,我可以安全地假设空字符'\0'会放在字符串的开头吗? 最佳答案 不,它不会包含NUL字节(除非你在那里放一个)。前向迭代器也不包含NUL字节,它只会迭代字符串本身中的字符。但是,NUL字节保证在.c_str()或.data()的末尾之后。示例程序:#include#include#includeintmain(){std::strings="Hello";std::cout(*i)(*i)输出:Forwards:H72e101l108l108o111Backwards
我习惯用enum{my_const=123;来定义常量},因为在类中,使用staticconstexpr需要类定义之外的一些代码(参见thisquestion)。但是-在函数体中呢?最近我一直注意到人们只是在他们的函数中使用constexpr变量(实际上甚至不屑于const它们),我想知道我是否是一个落后的傻瓜我的时代intfoo(intx){enum:int{bar=456};returnx+bar;}所以,我的问题是:在函数体内使用枚举而不是constexpr变量有什么好处吗? 最佳答案 如果bar是constexprintba
假设我有两个类,A和B,其中B是A的子类。我还有以下功能:voidfoo(boost::shared_ptra){boost::shared_ptrb=boost::dynamic_pointer_cast(a);//Error!}用gcc编译会出现以下错误:C:\Boost\include/boost/smart_ptr/shared_ptr.hpp:Inconstructor'boost::shared_ptr>::shared_ptr(constboost::shared_ptr&,boost::detail::dynamic_cast_tag)[withY=constA,T=c