返回* this,尝试级联,而不是返回引用

时间:2012-12-02 09:40:54

标签: c++

我的问题类似于此处提出的问题:How does "this" cascading work?

假设我有以下代码:

#include <iostream>
using namespace std;

class Time
  {
  public:
     Time( int = 0, int = 0, int = 0 );
     Time setHour( int );
     Time setMinute( int );
     void print( void );

  private:
     int hour;
     int minute;
  };

  Time::Time(int hr, int mn, int sc)
  {
     hour = hr;
     minute = mn;
  }

  void Time::print( void )
  {
     cout << "hour = " << hour << endl;
     cout << "minute = " << minute << endl;
  }

  Time Time::setHour( int h )
  {
     hour = ( h >= 0 && h < 24 ) ? h : 0;
     return *this;
  }


  Time Time::setMinute( int m )
  {
     minute = ( m >= 0 && m < 60 ) ? m : 0;
     return *this;
  }

int main()
{
   cout << "Hello, world!" << endl;
   Time t;
   t.setHour( 10 ).setMinute( 25 );
   t.print();
}

然后,很明显函数setMinute(25)没有在Time对象t上运行。请注意,函数setHour和setMinute不返回对Time对象的引用。

t.setHour(10)执行后发生了什么?函数setHour是否以某种方式返回对象t的“副本”,并且setMinute(25)正在副本上运行?我用-Wall编译了程序,没有返回错误或警告。

感谢您的协助。

2 个答案:

答案 0 :(得分:4)

您的分析似乎是正确的。这个表达

t.setHour( 10 )

返回一个临时的Time对象。然后,您可以在该临时呼叫上setMinute(25)。这反过来又返回另一个临时Time对象,该对象未分配给任何对象。因此setHour()t实例起作用,但setMinute()对临时行为起作用,在此行末尾消失

t.setHour( 10 ).setMinute( 25 );

答案 1 :(得分:0)

每个t的方法都返回对t的引用。引用是别名。所以,如果你做了

Time t;
 Time& tAgain = t;
 tAgain.setMinute( 25); 
tAgain.setMinute also alters t's time.

现在将这个简单的例子推断为级联。 t的每个方法都返回对自身的引用

Time &Time::setSecond( int s ) 
  {
      second = ( s >= 0 && s < 60 ) ? s : 0; 
      return *this; 
  }

所以在表达式中:

   t.setHour( 10 ).setMinute( 25 )

t.setHour( 10 )在t上调用setHour,然后返回对t的引用。在这种情况下,引用是临时的。因此,您可以将其视为在评估setHour时将上述行更改为以下内容:

tAgain.setMinute(25);

t.setHour返回了一个引用 - 类似于上面的tAgain。只是t本身的别名。