QMetaObject::invokeMethod: No such method的问题

在使用QMetaObject调用方法时遇到'No such method'错误,通过对Qt源码的分析发现是indexOfMethod返回值为-1。通过添加代码对签名进行规范化处理,成功解决了问题,并分享了解决方案。
摘要由CSDN通过智能技术生成

在做回QMeta调的过程中遇到这个问题,但是有的函数就成功了,有的不行,怎么改都是提示QMetaObject::invokeMethod: No such method

QObject* obj = temp.caller;

QByteArray slotName = temp.slotName;
if(obj != NULL && !slotName.isEmpty()){
    bool ok;//记录调用槽是否成功
    int parameterCount = obj->metaObject()->method(obj->metaObject()->indexOfMethod(slotName)).parameterTypes().length();
    QRegExp reg("^[^(]+");
    reg.indexIn (slotName);
    slotName = reg.cap (0).toLatin1 ();
    if(parameterCount==0){//如果形参个数为0个
        ok = QMetaObject::invokeMethod(obj, slotName);
    }
    else if(parameterCount==1){
        ok = QMetaObject::invokeMethod(obj, slotName, Q_ARG(QByteArray, cmdData));
    }
    else if(parameterCount==2){
        ok = QMetaObject::invokeMethod(obj, slotName, Q_ARG(qint64, seq), Q_ARG(QByteArray, cmdData));
    }
    else{
        ok = false;
    }
    if(!ok){
        qDebug()<
`QMetaObject::invokeMethod` 是Qt框架中用于动态调用对象方法的函数。它允许你在运行时调用对象的槽函数(slot),以及查询和设置属性(property)。这个函数非常灵活,可以用来实现信号与槽机制中的动态连接,以及在不直接访问对象的情况下执行对象的方法。 下面是 `QMetaObject::invokeMethod` 的基本使用方式: ```cpp bool QMetaObject::invokeMethod(QObject * object, const char * member, Qt::ConnectionType type = Qt::AutoConnection, const QGenericArgument & arg1 = QGenericArgument(), const QGenericArgument & arg2 = QGenericArgument(), ...) ``` 参数说明: - `object`:要调用方法的对象。 - `member`:要调用的方法名。 - `type`:指定信号和槽连接的方式,默认为 `Qt::AutoConnection`。 - `arg1`, `arg2`, ...:传递给方法的参数,这些参数需要使用 `Q_ARG` 宏来定义。 例如,如果你有一个对象 `myObject` 并想调用它的 `showMessage(const QString &)` 方法,你可以这样做: ```cpp QMetaObject::invokeMethod(myObject, "showMessage", Q_ARG(QString, "Hello World!")); ``` 这里使用了 `Q_ARG` 宏来指定传递给 `showMessage` 方法的参数。 除了传递参数外,`QMetaObject::invokeMethod` 还可以用于执行槽函数,而不传递任何参数: ```cpp QMetaObject::invokeMethod(myObject, "someSlotFunction"); ``` 还可以指定连接类型,例如异步连接: ```cpp QMetaObject::invokeMethod(myObject, "someSlotFunction", Qt::QueuedConnection); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值