《Effective C++》——条款20:宁以pass-by-reference-to-const替换pass-by-value

切割(slicing)问题

请看下面代码:

class Window
{
public:
    ...
    std::string name()const;     //返回窗口名称
    virtual void display()const; //显示窗口和其内容
};
class WindowWithScrollBars:public Window
{
public:
    ...
    virtual void display()const;
};

现在假设你希望写个函数打印窗口名称,然后显示该窗口,代码如下所示:

void printNameAndDisplay(Window w)//不正确,参数可能被切割
{
    std::cout << w.name();
    w.display();
}
WindowWithScrollBars wwsb;
printNameAndDisplay(wwsb);//将调用Window::display();

在调用printNameAndDisplay函数时,参数永远都会被构造成一个Window对象。

解决的办法是以常引用的方式传递w:

void printNameAndDisplay(const Window& w)
{
    std::cout << w.name();
    w.display();
}
WindowWithScrollBars wwsb;
printNameAndDisplay(wwsb);//将调用WindowWithScrollBars::display();

因为references往往以指针实现出来,因此传递引用通常意味着真正传递的是指针。

 

posted @ 2015-07-17 16:45  Rosanne  阅读(162)  评论(0编辑  收藏  举报