0

我正在尝试将 LinqBridge 与 Compact Framework 2.0 一起使用,但在Where调用 Linq 方法时出现 MethodAccessException。

首先,我尝试使用来自BitBucket的预编译程序集、我自己的 fork 和一些小的 tweeks 来为 CF 编译,以及来自他在 gitHub 上的 sdf repo 的 ctacke 的 fork。

我一直很注意在构建之间进行清理和清理设备上的部署目录。此外,我一直在使用 DotPeek 进行反编译,以确认 LinqBridge 中应该公开的所有内容都显示为公开。

更新 1

在我使用以下代码之前它工作正常

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;
    }
}

更新 2

以下代码在使用紧凑框架 2.0(使用来自 raboof 和 ctacke 的 fork 的预编译 dll)运行时引发 MethodAccessException,但Compact 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);
        }
    }
}
4

1 回答 1

0

问题似乎是由于在 Where 调用中使用私有类型作为 TSource。这有点超出我的理解水平,但我怀疑这个问题可能是由于编译器生成的代码导致的,这些代码称为显示类,用于包装 lambda。如果有人对此有更好的理解,请随时发布答案

于 2017-05-25T21:00:52.083 回答