voID foo(<any value type>[] data){}
在C#2.0中.如果我声明它
voID foo(ValueType[] data){}
它编译,然后data []中的元素被视为它们是从对象派生的,例如我不能说出类似的话
fixed (voID* pData = data){}
我想避免将voID *作为参数 – 我只是希望能够接受任何值类型数组,然后对它进行非托管 *** 作.
ETA:此外,这也有同样的问题:
public static unsafe voID foo<T>(T[] data) where T:struct{ fixed(voID *p = data){}}
如果你想知道.修复失败,因为它被视为托管类型 – CS0208,无法声明指向托管类型的指针.见下面的“mm”.我认为他是对的…它可能无法完成.
解决方法 我不认为使用C#是可能的.从编译时开始,结构不会从System.ValueType继承(但是松散),因此您无法通过多态与Foo的方法签名匹配.根据语言规范,泛型也出来了:“An unmanaged-type is any type that isn’t a reference-type,a type-parameter,or a generic struct-type and
contains no fIElds whose type is not an unmanaged-type.”
因此,无论结构约束如何,您都无法获取T []的地址.
您可以将结构类型(例如,bar)声明为Foo的参数,编译代码,并在IL级别更改方法签名:
.method private hIDebysig static voID Foo(valuetype [mscorlib] System.ValueType [] args)cil managed
然后是电话:
IL_0020:call voID ConsoleApplication1.Program :: Foo(valuetype [mscorlib] System.ValueType [])
虽然我能够运行生成的程序,但我不知道它有什么样的副作用.此外,即使您可以引用修改后的函数,也无法从C#调用它,因为在编译之后,结构体不再继承System.ValueType,因此方法签名不匹配.
总结以上是内存溢出为你收集整理的c# – 将任何值类型的数组作为形式参数全部内容,希望文章能够帮你解决c# – 将任何值类型的数组作为形式参数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)