我正在尝试将LinqBridge与Compact Framework 2.0一起使用,但是当调用Linq Where
方法时,我得到一个MethodAccessException。
首先,我尝试使用来自BitBucket的预编译程序集,我自己的fork和一些小的tweek来编译CF,以及ctacke从他的sdf repo在gitHub上的fork。
我一直小心清理构建和清理设备上的部署目录。此外,我一直在使用DotPeek进行反编译,以确认LinqBridge中应该公开的所有内容都显示为公开。
在我使用以下代码之前,它工作正常
public static IEnumerable<TSource> Where<TSource>(this IEnumerable<TSource> source, Func<TSource, bool> predicate)
{
foreach (TSource source1 in source)
{
if (predicate(source1))
yield return source1;
}
}
以下代码在使用compact framework 2.0(使用raboof和ctacke的fork的预编译dll)运行时抛出MethodAccessException,但紧凑Famework 3.5中使用不(使用LinqBridge而不是System.Core) ,或完整框架2.0。所以我怀疑这是Compact Framework 2.0 CLR中的一个错误。
using System.Linq;
static class Program
{
private enum Something { a, b, c };
[MTAThread]
static void Main()
{
var dict = new Dictionary<Something, Something>();
dict.Add(Something.a, Something.a);
dict.RemoveByValue(Something.a);
}
}
public static class DictionaryExtentions
{
public static void RemoveByValue<TKey, TValue>(this IDictionary<TKey, TValue> dict, TValue value)
{
foreach (var item in dict.Where(kvp => kvp.Value.Equals(value)).ToArray())
{
dict.Remove(item.Key);
}
}
}
答案 0 :(得分:0)
问题似乎是由于在Where调用中使用私有类型作为TSource。这略高于我的理解水平,但我怀疑问题可能是由于编译器生成的代码(称为显示类)用于包装lambdas。 如果有人对此有更好的理解,请随意发表答案