Visual C++:在明显的情况下没有机会
Visual C++ : No devirtualization in obvious cases?
在观看visual c++(VS2017 RC)生成的代码时,我非常惊讶地发现在简单的情况下动态分支(虚拟调用)。
因此,我使用编译器资源管理器尝试了以下代码:
struct Base
{
virtual void foo() = 0;
};
struct Impl : Base
{
void foo() override;
};
Impl g_impl;
void globalCall()
{
g_impl.foo();
}
void localCall()
{
Impl i;
i.foo();
}
void tempCall()
{
Impl().foo(); // dynamic branching generated!
}
struct Class
{
void memberCall();
Impl impl;
};
void Class::memberCall()
{
impl.foo(); // dynamic branching generated!
}
编译器资源管理器链接:https://godbolt.org/g/RmUku2
对于临时案件和成员案件,似乎没有出现任何机会。那么,这是编译器实现质量的问题,还是有技术上的正当理由导致这样的结果?
只是错过了机会不足的案例。自从支持去机会化的第一个版本,即VS 2013以来,情况一直如此。其他编译器gcc、icc和clang在所有情况下都执行去机会化。一般来说,最好显式指定final
,而不是依赖编译器来学究式地执行虚拟化。用final
标记Impl.foo
可以实现所有情况下的优化。
相关文章:
- 在没有太多条件句的情况下,我如何避免被零除
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 在未初始化映射的情况下,将值插入到映射的映射中
- 是默认情况下分配给char数组常量的值
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 如何在不产生任何垃圾的情况下获得C中的像素
- 在已经使用Git的情况下减少编译时间
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- 如何在没有信号的情况下从C++执行QML插槽
- 如何在不知道向量大小的情况下输入向量内部的向量?
- 为什么在某些情况下不写入此文件?
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 在没有Xcode的情况下在Mac捆绑包中嵌入框架
- UE4-如何在给定4个屏幕坐标的情况下缩放纹理或材质
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 在C++中如何在没有pow的情况下进行基础计算
- 松弛原子与无同步情况下的记忆连贯性
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 我是c ++的新手,你能解释一下在这种情况下的指针吗
- Visual C++:在明显的情况下没有机会