反射方法调用时的一个错误:参数计数不匹配( parameter count mismatch )

本文介绍了一个关于在.NET中使用反射调用带有参数数组的方法时遇到的问题及解决方案。当通过反射调用方法并将参数数组直接传递给Invoke方法时,会引发参数数量不匹配的错误。文章提供了一种简单的解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大致情况是这样,我在一个DLL定义了一个方法A,A的参数为一个参数数组;

然后使用反射调用其中的方法A,并且传递一个object数组到方法A

大致代码如下:

 

//获取程序集
currentAssembly = Assembly.LoadFrom(System.AppDomain.CurrentDomain.BaseDirectory + "\\" + System.Configuration.ConfigurationManager.AppSettings["PluginCatalog"] + "\\" + requestedNameSpace + "\\" + requestedNameSpace + ".dll");

//获取命名空间和类名
currentType = currentAssembly.GetType(requestedNameSpace + "." + requestedClassName);

//获取方法的名称
currentMethod = currentType.GetMethod(requestedMethodName);

//创建实例对象
currentInstance = currentAssembly.CreateInstance(requestedNameSpace + "." + requestedClassName);

//具体方法的调用并传入方法数组
 StrinForBack = (string)currentMethod.Invoke(currentInstance, postedParams);
 

这样如果你直接把接收到的参数数组postedParams直接传递给invoke方法的话,就会产生标题所述的错误;

后来查阅MSDN,这个帖子让我茅塞顿开

Parameter count mismatch

应该这样理解:Invoke方法的参数当中有一个自己的object[],正好你传递的参数也是object[],这样的话invoke就会把你参数数组里面的第一个参数作为参数传递给你要调用的方法,于是就报错了。

解决问题的如下:

postedParams = new object[] { postedParams };

StrinForBack = (string)currentMethod.Invoke(currentInstance, postedParams);

╮(╯_╰)╭


原文地址:http://www.cnblogs.com/binarytree/archive/2010/04/21/1717491.html

void Login::queryAccount() { // 设置 sql 语句的查询 QLineEdit *lineEditUser = ui->lineEdit_account; QLineEdit *lineEditPass = ui->lineEdit_password; // 使用问号占位符 QString queryStr = "select COUNT(*) from Users where UserID = ? AND UserPassword = ?"; QSqlQuery query; query.prepare(queryStr); // 按顺序绑定参数 query.addBindValue(lineEditUser->text()); query.addBindValue(lineEditPass->text()); // 打印 SQL 语句和绑定的参数 qDebug() << "SQL Query:" << queryStr; qDebug() << "Bound Values:"; qDebug() << "Param 1 =" << lineEditUser->text(); qDebug() << "Param 2 =" << lineEditPass->text(); // 执行查询 if (query.exec()) { if (query.next()) { int count = query.value(0).toInt(); if (count > 0) { qDebug() << "账号密码验证成功"; // 在这里可以添加登录成功后的逻辑,例如打开新窗口等 close(); MainWindow *w = new MainWindow; w->show(); } else { QMessageBox::warning(this, "提示", "账号或密码错误"); qDebug() << "账号或密码错误"; } } else { QMessageBox::critical(this, "错误", "查询结果获取失败"); qDebug() << "查询结果获取失败"; } } else { QMessageBox::critical(this, "错误", "查询执行失败: " + query.lastError().text()); if (!query.exec()) { QSqlError error = query.lastError(); qDebug() << "查询执行失败:" << error.text(); qDebug() << "错误类型:" << error.type(); qDebug() << "错误编号:" << error.nativeErrorCode(); QMessageBox::critical(this, "错误", "查询执行失败: " + error.text()); } } } void Login::on_pushButton_log_clicked() { queryAccount(); }查询执行失败: "Parameter count mismatch"错误原因怎么改
最新发布
03-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值