2

我有一个类似于这里提出的问题的问题:“这个”级联如何工作?

假设我有以下代码:

#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) 没有在时间对象 t 上运行。请注意,函数 setHour 和 setMinute 不返回对 Time 对象的引用。

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

感谢你的协助。

4

2 回答 2

4

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

t.setHour( 10 )

返回一个临时Time对象。然后你调用setMinute(25)那个临时的。这反过来又返回另一个临时Time对象,它没有分配给任何东西。所以setHour()作用于t实例,但setMinute()作用于一个临时的,它在这一行的末尾消失

t.setHour( 10 ).setMinute( 25 );
于 2012-12-02T09:43:25.020 回答
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 本身的别名。

于 2012-12-02T09:48:22.280 回答