第12章复习题答案
1.a.语法是正确的,但该构造函数没有将str指针初始化。该构造函数应将指针设置成NULL或使用new [ ]来初始化它。
b.该构造函数没有创建新的字符串,而只是复制了原有字符串的地址。它应当使用new [ ]和strcpy( )。
c.它复制了字符串,但没有给它分配存储空间,应使用new char[len + 1]来分配适当数量的内存。
2.首先,当这种类型的对象过期时,对象的成员指针指向的数据仍将保留在内存中,这将占用空间,同时不可访问,因为指针已经丢失。可以让类析构函数删除构造函数中new分配的内存,来解决这种问题。其次,析构函数释放这种内存后,如果程序将这样的对象初始化为另一个对象,则析构函数将试图释放这些内存两次。这是因为将一个对象初始化为另一个对象的默认初始化,将复制指针值,但不复制指向的数据,这将使两个指针指向相同的数据。解决方法是,定义一个复制构造函数,使初始化复制指向的数据。第三,将一个对象赋给另一个对象也将导致两个指针指向相同的数据。解决方法是重载赋值运算符,使之复制数据,而不是指针。
3.C++(www.cppentry.com)自动提供下面的成员函数:
如果没有定义构造函数,将提供默认构造函数。
如果没有定义复制构造函数,将提供复制构造函数。
如果没有定义赋值运算符,将提供赋值运算符。
如果没有定义析构函数,将提供默认析构函数。
如果没有定义地址运算符,将提供地址运算符。
默认构造函数不完成任何工作,但使得能够声明数组和未初始化的对象。默认复制构造函数和默认赋值运算符使用成员赋值。默认析构函数也不完成任何工作。隐式地址运算符返回调用对象的地址(即this指针的值)。
4.应将personality成员声明为字符数组或car指针,或者将其声明为String对象或string对象。该声明没有将方法设置为公有的,因此会有几个小错误。下面是一种可能的解决方法,修改的地方以粗体显示:
下面是另一种解决方案:
注意,对于语句5和6,有些编译器还将调用默认的赋值运算符。
b.类应定义一个复制数据(而不是地址)的赋值运算符。