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