我有以下方法:
void MyMethod(params object[] args)
{
}
我试图使用object[]
类型的参数调用:
object[] myArgs = GetArgs();
MyMethod(myArgs);
它编译得很好,但在MyMethod
I args == { myArgs}
内,即一个数组,其中一个元素是我的原始参数。显然我想args = myArgs
,我做错了什么?
编辑:
Jon Skeet实际上是正确的,GetArgs()
确实将事物包装在一个元素数组中,对不起这个愚蠢的问题。
答案 0 :(得分:19)
你所描述的内容根本不会发生。除非需要,否则编译器会不创建包装器数组。这是一个简短但完整的程序,展示了这一点:
using System;
class Test
{
static void MyMethod(params object[] args)
{
Console.WriteLine(args.Length);
}
static void Main()
{
object[] args = { "foo", "bar", "baz" };
MyMethod(args);
}
}
根据你的问题,这将打印1 - 但它不打印,它打印3. args
的值直接传递给MyMethod
,没有进一步扩展。
您的代码不是您发布的代码,或者是GetArgs
内的“包装”。
您可以强制将args
强制转换为object
。例如,如果我将Main
的最后一行更改为:
MyMethod((object) args);
... 然后它打印1,因为它有效地调用了MyMethod(new object[] { args })
。