书错了?2002 年指向对象的指针数组
Book mistake? Array of pointers to objects in 2002
我正在阅读Herbert Schildt(2002)的一本书并学习虚函数。那里有一个示例程序,作者保证它是可编译的。但是,编译器不会编译它。编译器说问题出在
shapes[0] = &Square(2.0);
它可能与指向对象的指针数组有关,也可能与 C++11 有关(如果是这样,我不明白为什么要禁用数组的此功能)。该程序有点长,所以我对其进行了剪切并简化了它以隔离问题并使其易于阅读。
#include <iostream>
using namespace std;
// Base class for two-dimensional objects:
class TwoDShape {
double side;
char name[20];
public:
TwoDShape(double x) {
side = x;
}
double getSide() { return side; }
void setSide(double w) { side = w; }
virtual double area() = 0;
};
// Derived class for Squares:
class Square : public TwoDShape {
public:
Square(double x) : TwoDShape(x) { };
double area() { return getSide() * getSide(); }
};
int main() {
TwoDShape *shapes[3];
shapes[0] = &Square(2.0);
shapes[1] = &Square(6.0);
shapes[2] = &Square(9.0);
return 0;
}
好吧,在 2000 年代左右编写的旧C++编译器(至少其中一些)实际上允许这样做。但是,在这里使用这种结构显然是错误的。
Square(x,y)
创建一个临时对象,该对象在创建后立即被删除。因此,所有存储的指针都变得无效,并且程序不会仅仅因为它们不再使用而崩溃。
因此,现代C++编译器将此视为错误("临时地址")并拒绝生成代码。
相关文章:
- 对象指针在c++中是如何工作的
- C++ 对象指针数组的复制构造函数
- 在对象指针上调用 Delete 是否会递归删除其动态分配的成员
- 什么更好?返回对象指针列表?或返回指向对象列表的指针?
- 正确初始化和销毁对象指针的C++数组?
- 如何深度复制链表对象指针
- 对象指针 c++ 的全局向量错误
- 如何将 c++ 类包装到 python 中,以便我可以使用 pybind11 访问其成员的公共方法(成员是一个对象指针)
- 静态对象指针
- 正在将对象指针数组初始化为NULL
- 如何使用条件表达式返回对象指针?
- std::flush可以用于将对象指针转换为其封闭数组指针吗
- 使用C对象指针构建PyObject*
- 如何在使用对象指针时访问成员函数
- 静态强制转换允许转换对象指针,但不允许转换整数
- C++ abort() 在函数内的抽象类对象指针调用上
- 指向函数的对象指针
- 访问指向对象指针向量的指针的第一个元素?
- 如何将对象/指针正确存储到 Qlist 中
- 对象指针打印结果以相反的顺序进行