c# – 运行到System.MissingMethodException:使用PrivateObject找不到方法

前端之家收集整理的这篇文章主要介绍了c# – 运行到System.MissingMethodException:使用PrivateObject找不到方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
基本上,我的一些测试是成功的,有些是失败的.根据Skeet先生的出色建议,我创建了一个完整的代码示例,以确认我并不疯狂.这是代码
namespace ClassLibrary
{
    using System;

    public class Manager
    {
        private int SampleMethod(int id)
        {
            return id;
        }
    }
}

我的测试是:

namespace UnitTestProject
{
    using System;
    using Microsoft.VisualStudio.TestTools.UnitTesting;

    [TestClass]
    public class UnitTest
    {
        [TestMethod]
        public void TestPasses()
        {
            var privateInfo = new PrivateObject(new ClassLibrary.Manager());
            var actual = privateInfo.Invoke("SampleMethod",1);
        }

        [TestMethod]
        public void TestErrorsOut()
        {
            var privateInfo = new PrivateObject(new ClassLibrary.Manager());
            var actual = privateInfo.Invoke("SampleMethod",0);
        }

        [TestMethod]
        public void TestWorksAsWell()
        {
            var privateInfo = new PrivateObject(new ClassLibrary.Manager());
            privateInfo.Invoke("SampleMethod",new object[] { 0 });
        }

        [TestMethod]
        public void TestAlsoErrorsOut()
        {
            var privateInfo = new PrivateObject(new ClassLibrary.Manager());
            var types = new Type[] { typeof(int) };
            var actual = privateInfo.Invoke("SampleMethod",types,0);
        }
    }
}

第一个测试(TestPasses())有效.

第二个测试(TestErrorsOut())失败,出现以下错误
{“找不到方法’ClassLibrary.Manager.SampleMethod’.”}

令人困惑的是错误是一致的,但实际测试几乎完全相同.这没有道理.我在VS2012 RC和VS2010上尝试了这个,结果相同.

我唯一能想到的是“0”是否会被转换成除了int之外的东西,这意味着它找不到SampleMethod的方法签名?我尝试了第三个测试来显式传入我正在寻找的类型(TestAlsoErrorsOut()),但是同样错误也会出错.

想法?谢谢.

编辑添加

通过使用Ian的建议使用obj []而不是params obj []重载,它可以工作(测试TestWorksAsWell()).这就解释了为什么TestAlsoErrorsOut()失败,因为我使用的是params方法,它不适用于Type [].所以,这是固定的.但为什么?为什么params obj []在传递1时工作,而不是0?

解决方法

根据文档( http://msdn.microsoft.com/en-us/library/ms243710.aspx),参数应该作为一个对象数组传递.显式传递对象数组似乎正常工作:
var actual = (int)privateInfo.Invoke("SampleMethod",new object[] {0});

单独传递0似乎会导致编译器选择此重载

Invoke(string name = "SampleMethod",System.Reflection.BindingFlags bindingFlags = Default,object[] args = {object[0]})

猜你在找的C#相关文章