Qt进修之路(9):深入相识信号槽
副标题#e#
槽函数和普通的C++成员函数没有很大的区别。它们也可以使virtual的;可以被重写;可以使public、protected可能 private的;可以由其它的C++函数挪用;参数可以是任何范例的。假如要说区别,那就是,槽函数可以和一个信号相毗连,当这个信号产生时,它可以被自动挪用。
connect()语句的原型雷同于:
connect(sender, SIGNAL(signal), receiver, SLOT(slot));
这里,sender和receiver都是QObject范例的,singal和slot都是没有参数名称的函数签名。SINGAL()和SLOT()宏用于把参数转换成字符串。
深入的说,信号槽尚有更多大概的用法,如下所示。
一个信号可以和多个槽相连:
connect(slider, SIGNAL(valueChanged(int)),
spinBox, SLOT(setValue(int)));
connect(slider, SIGNAL(valueChanged(int)),
this, SLOT(updateStatusBarIndicator(int)));
留意,假如是这种环境,这些槽会一个接一个的被挪用,可是它们的挪用顺序是不确定的。
多个信号可以毗连到一个槽:
connect(lcd, SIGNAL(overflow()),
this, SLOT(handleMathError()));
connect(calculator, SIGNAL(divisionByZero()),
this, SLOT(handleMathError()));
这是说,只要任意一个信号发出,这个槽就会被挪用。
一个信号可以毗连到别的的一个信号:
connect(lineEdit, SIGNAL(textChanged(const QString &)),
this, SIGNAL(updateRecord(const QString &)));
这是说,当第一个信号发出时,第二个信号被发出。除此之外,这种信号-信号的形式和信号-槽的形式没有什么区别。
槽可以被打消链接:
disconnect(lcd, SIGNAL(overflow()),
this, SLOT(handleMathError()));
这种环境并不常常呈现,因为当一个工具delete之后,Qt自动打消所有毗连到这个工具上面的槽。
为了正确的毗连信号槽,信号和槽的参数个数、范例以及呈现的顺序都必需沟通,譬喻:
connect(ftp, SIGNAL(rawCommandReply(int, const QString &)),
this, SLOT(processReply(int, const QString &)));
这里有一种破例环境,假如信号的参数多于槽的参数,那么这个参数之后的那些参数城市被忽略掉,譬喻:
connect(ftp, SIGNAL(rawCommandReply(int, const QString &)),
this, SLOT(checkErrorCode(int)));
这里,const QString &这个参数就会被槽忽略掉。
#p#副标题#e#
假如信号槽的参数不相容,可能是信号或槽有一个不存在,可能在信号槽的毗连中呈现了参数名字,在Debug模式下编译的时候,Qt城市很智能的给出告诫。
在这之前,我们仅仅在widgets中利用到了信号槽,可是,留意到connect()函数其实是在QObject中实现的,并不范围于GUI,因此,只要我们担任QObject类,就可以利用信号槽机制了:
class Employee : public QObject
{
Q_OBJECT
public:
Employee() { mySalary = 0; }
int salary() const { return mySalary; }
public slots:
void setSalary(int newSalary);
signals:
void salaryChanged(int newSalary);
private:
int mySalary;
};
在利用时,我们给出下面的代码:
void Employee::setSalary(int newSalary)
{
if (newSalary != mySalary) {
mySalary = newSalary;
emit salaryChanged(mySalary);
}
}
这样,当setSalary()挪用的时候,就会发出salaryChanged()信号。留意这里的if判定,这是制止递归的方法!还记得前面提到的轮回毗连吗?假如没有if,当呈现了轮回毗连的时候就会发生无限递归。
出处: http://devbean.blog.51cto.com/448512/199461