QT5:QObject::connect()介绍

栏目: C++ · 发布时间: 6年前

内容简介:学习QT,绕不卡信号与槽,这是QT的一大重点,也是亮点。而QT5则丰富了信号与槽的重载函数,足足增加到了5个,分别如下:最后,结束语,希望自己早早掌握QT。

学习QT,绕不卡信号与槽,这是QT的一大重点,也是亮点。而QT5则丰富了信号与槽的重载函数,足足增加到了5个,分别如下:

  1. QMetaObject::Connection connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type = Qt::AutoConnection)

  2. QMetaObject::Connection connect(const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type = Qt::AutoConnection)

  3. QMetaObject::Connection connect(const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type = Qt::AutoConnection)

  4. QMetaObject::Connection connect(const QObject *sender, PointerToMemberFunction signal, Functor functor)

  5. QMetaObject::Connection connect(const QObject *sender, PointerToMemberFunction signal, const QObject *context, Functor functor, Qt::ConnectionType type = Qt::AutoConnection)
    其中,第3个和第5个重载最具有特点。

首先看看第3个重载函数,查看QT的help文档,可以看到给出的一个例子:

QLabel *label = new QLabel;
QLineEdit *lineEdit = new QLineEdit;

QObject::connect(lineEdit, &QLineEdit::textChanged, label, &QLabel::setText);

但是当信号由多个重载时,这么直接使用就会出现编译失败,因为编译器找不到对应方法。我们可以通过函数指针的变量来来指定实际的信号,如下图所示,黄色框内的代码和绿色框内的等价。

QT5:QObject::connect()介绍

之后,看看第5个重载函数,也看看help文档给出的代码例子。

QTcpSocket *socket = new QTcpSocket; socket->connectToHost("qt-project.org", 80); QObject::connect(socket, &QTcpSocket::connected, [=] () { socket->write("GET " + page + "\r\n"); });

可以明显看到槽函数变成了Lambda表达式,这对于某些简单的槽函数,可就节省了思考方法名的时间了,很大程度提升了便捷性。而Lambda表达式的编写方法,可以具体查看。

最后,结束语,希望自己早早掌握QT。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

形式感+:网页视觉设计创意拓展与快速表现

形式感+:网页视觉设计创意拓展与快速表现

晋小彦 / 清华大学出版社 / 2014-1-1 / 59.00元

网页设计师从早年的综合性工作中分化出来,形成了相对独立的专业岗位,网页设计也不再是单纯的软件应用,它衍生出了许多独立的研究方向,当网站策划、交互体验都逐渐独立之后,形式感的突破和表现成为网页视觉设计的一项重要工作。随着时代的发展,网页设计更接近于一门艺术。网络带宽和硬件的发展为网页提供了使用更大图片、动画甚至视频的权利,而这些也为视觉设计师提供了更多表现的空间。另外多终端用户屏幕(主要是各种移动设......一起来看看 《形式感+:网页视觉设计创意拓展与快速表现》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具