jjzjj

fno-rtti

全部标签

c++ - 我试过 : valgrind, _GLIBCXX_DEBUG,-fno-strict-aliasing;我该如何调试这个错误?

我有一个非常奇怪的错误,我花了几天时间试图弄清楚,所以现在我想看看是否有人有任何意见可以帮助我理解发生了什么。一些背景。我正在从事一个软件项目,该项目涉及使用Boost1.45向Python2.7.1添加C++扩展,因此我的所有代码都通过Python解释器运行。最近,我对破坏了我们的回归测试之一的代码进行了更改。这个回归测试可能对数值波动过于敏感(例如不同的机器),所以我应该解决这个问题。但是,由于此回归在产生原始回归结果的同一台机器/编译器上发生故障,因此我将结果的差异追溯到这段数字代码(可证实与我更改的代码无关):c[3]=0.25*(-3*df[i-1]-23*df[i]-13*

c++ - 自动化 LLVM 风格的 RTTI 代码

对于特定的类层次结构,我需要知道基类引用是否是特定派生类的实例。由于不同的原因,我不能在这里使用标准的C++RTTI,我需要实现一个自定义的instanceof机制。LLVM-stleRTTI会满足我的需求,但我想知道是否存在一种方法(以某种方式使用模板)来自动执行classof方法?是否有其他/更简单的实现这种机制可以知道基类是否是派生类的实例?我的约束:我没有多重继承,但我有多个继承级别。对内存占用的影响必须尽可能小,并且不可能执行动态分配。 最佳答案 Iwaswonderingifitwouldexistsaway(someh

c++ - clang、std::function 和 -fno-rtti

我在Windows上通过clang-cl使用Clang5,在使用std::function-fno-rtti)时遇到问题.这是我无法编译的示例:#includevoidfoo(std::functionra2){}intmain(){autobar=[](){};foo(bar);returnEXIT_SUCCESS;}命令行:clang-cltest.cpp-Xclang-fno-rtti错误是:C:\ProgramFiles(x86)\MicrosoftVisualStudio\Preview\Community\VC\Tools\MSVC\14.13.26128\include\

c++ - 从函数返回后丢失 RTTI 信息

给定一个类和子类:classEvent{...}classNote:publicEvent{...}Note被克隆并存储在函数f()中的指针中。类型信息保存在指针中,可以通过dynamic_cast恢复:voidf(){pEvent=pNote->Clone();//createacloneofaNoteASSERT(dynamic_cast(pEvent));//checkthepointer,hereitworks}现在,从f()返回后,类型信息丢失了:f();ASSERT(dynamic_cast(pEvent));//->"Accessviolation-noRTTI-data

c++ - C++ ABI 是否指定 vTable 和 RTTI 信息应该如何存在?

像GCC/VC这样的流行实现使用多态对象的第一个size_t空间作为指针,指向一个vtable结构。这是最新的C++ABI的一部分吗?RTTI的实现如何,C++ABI有没有规定如何实现?谢谢 最佳答案 不,C++标准没有指定这些应该如何实现。没有单一的C++ABI。 关于c++-C++ABI是否指定vTable和RTTI信息应该如何存在?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio

c++ - 为什么 RTTI 似乎不受欢迎?

似乎在我读到的所有地方,要么是某个库吹嘘不需要RTTI,要么是一篇文章建议不要使用它。它有什么不好,为什么不需要它是一件好事?谢谢 最佳答案 因为使用它通常意味着您正在颠覆多态性(if(typeisfoo){dothis;}elseif(typeisbar){dothat;}else...),这通常意味着您将自己设计到了一个角落,需要重新考虑您的设计。因为C++编译器的作者在优化多态行为方面投入了大量精力,但在优化RTTI的使用方面投入了大量精力。 关于c++-为什么RTTI似乎不受欢迎

c++ - std::map 和 -fno-implicit-templates

我正在尝试使用g++4.4进行编译并链接一个使用STL的简单程序。我正在尝试使用-fno-implicit-templates来做到这一点,因此必须显式实例化所有模板。我不明白为什么此代码有效:#include//templateclassstd::map;templateclassstd::_Rb_tree,std::_Select1st>,std::less,std::allocator>>;intmain(){std::maptable;return0;}我希望这个程序需要这一行:templateclassstd::map;,但是该行不会使程序链接。std::_Rb_treeli

c++ - "this"指针是否启用了 RTTI?

我试图在对象的继承树中的其中一个类的构造函数中发现对象的派生程度最高的类。我现在已经在这上面花了几个小时,并且不知道我还能怎么做或者为什么它没有意义。这似乎很有道理,但它拒绝工作。我找到了很多关于RTTI的页面,但基本上没有找到。我将在我的测试用例及其输出之后继续解释。来源:#include#include#includeclassA{public:A(std::stringfoo);virtualvoidbar(A*a)=0;};classB:publicA{public:B();virtualvoidbar(A*a);};A::A(std::stringfoo){std::cout

c++ - C++ POD 类型是否具有 RTTI?

据我了解RTTI在各种C++编译器(例如GCC)中的实现方式,指向type_info数据的指针存储在每个类的vtable数据中。也如前所述here,POD类型可能没有vtable。但是,如果POD类型可能没有vtable,那么指向type_info的指针存储在哪里?我知道它是特定于实现的,但最好了解C++编译器(例如GCC)的内部结构。 最佳答案 有两种类型(对于RTTI而言):多态类型和非多态类型。多态类型是一种本身或从基类继承的具有虚函数的类型。非多态类型是一切;这包括POD类型,但也包括许多其他类型。如果你有一个指向多态类型T

c++ - 不使用 RTTI 缓存不同派生类型的设计模式

假设我有一系列类都实现相同的接口(interface),可能用于调度:classFoo:publicIScheduler{public:Foo(Descriptord):IScheduler(d){}/*methods*/};classBar:publicIScheduler{public:Bar(Descriptord):IScheduler(d){}/*methods*/};现在假设我有一个Scheduler类,您可以要求为给定的描述符启动一个IScheduler派生类。如果它已经存在,您将获得对它的引用。如果不存在,则会创建一个新的。一个假设的调用类似于:Foo&foo=sche