我的问题类似于此处提出的问题: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编译了程序,没有返回错误或警告。
感谢您的协助。
答案 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本身的别名。