编译器使用类的行为
behavior of the compiler using classes
本文关键字:编译器 更新时间:2023-10-16
#include <list>
using std::list;
class foo { ...
class bar : public foo { ...
static void print_all(list<foo*> &L) { ...
list<foo*> LF;
list<bar*> LB;
...
print_all(LF); // works fine
print_all(LB); // static semantic error
我想我知道为什么编译器不允许第二次调用。谁能举一个编译器接受这种调用可能发生的坏事的例子?
当然! 如果print_all这样做怎么办:
L.push_back(new Foo);
现在,您的 Bar 指针列表有一个指向不是 Bar 的 Foo 对象的指针。 如果你随后尝试调用 Bar 中不存在的 Foo 类中的方法,你将得到某种严重的运行时问题,因为该方法在 Foo 对象中不存在。
希望这有帮助!
代码中发生了两件不同的事情,有不同的解释。第一个问题是模板的不同实例化是不相关的,即使实例化类型是相关的。在这种特殊情况下,std::list<foo*>
与std::list<bar*>
没有关系,即使foo
是bar
的基数。这是语言设计的一部分,什么也做不了。
第二个问题,不是编译器所抱怨的,是通常不能通过引用将derived
容器用作base
的容器。这是@templatetypedef提出的问题 - 但同样,这不是代码中的问题,它将在不同的示例中:
void f( base** p );
int main() {
derived *d;
f( &d ); // error
}
在这种情况下,问题是,正如@templatetypedef指出的那样,使用 derived
的指针/容器代替以非常量方式base
的指针/容器容易出错,因为您可以将非derived
类型存储在指针/容器上。
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?