Методы расширения должны быть определены в неэквивалентном статическом классе

Я получаю сообщение об ошибке:

Методы расширения должны быть определены в неэквивалентном статическом классе

В строке:

public class LinqHelper

Вот вспомогательный класс, основанный на коде Марка Гавелла. Я действительно смущен относительно того, что означает эта ошибка, поскольку я уверен, что она отлично работает, когда я оставил ее в пятницу!

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Linq.Expressions;
using System.Reflection;

/// <summary>
/// Helper methods for link
/// </summary>
public class LinqHelper
{
    public static IOrderedQueryable<T> OrderBy<T>(this IQueryable<T> source, string property)
    {
        return ApplyOrder<T>(source, property, "OrderBy");
    }
    public static IOrderedQueryable<T> OrderByDescending<T>(this IQueryable<T> source, string property)
    {
        return ApplyOrder<T>(source, property, "OrderByDescending");
    }
    public static IOrderedQueryable<T> ThenBy<T>(this IOrderedQueryable<T> source, string property)
    {
        return ApplyOrder<T>(source, property, "ThenBy");
    }
    public static IOrderedQueryable<T> ThenByDescending<T>(this IOrderedQueryable<T> source, string property)
    {
        return ApplyOrder<T>(source, property, "ThenByDescending");
    }
    static IOrderedQueryable<T> ApplyOrder<T>(IQueryable<T> source, string property, string methodName)
    {
        string[] props = property.Split('.');
        Type type = typeof(T);
        ParameterExpression arg = Expression.Parameter(type, "x");
        Expression expr = arg;
        foreach (string prop in props)
        {
            // use reflection (not ComponentModel) to mirror LINQ
            PropertyInfo pi = type.GetProperty(prop);
            expr = Expression.Property(expr, pi);
            type = pi.PropertyType;
        }
        Type delegateType = typeof(Func<,>).MakeGenericType(typeof(T), type);
        LambdaExpression lambda = Expression.Lambda(delegateType, expr, arg);

        object result = typeof(Queryable).GetMethods().Single(
                method => method.Name == methodName
                        && method.IsGenericMethodDefinition
                        && method.GetGenericArguments().Length == 2
                        && method.GetParameters().Length == 2)
                .MakeGenericMethod(typeof(T), type)
                .Invoke(null, new object[] { source, lambda });
        return (IOrderedQueryable<T>)result;
    }
}

Ответ 1

изменить

public class LinqHelper

to

public static class LinqHelper

При создании метода расширения следует учитывать следующие моменты:

  • Класс, который определяет метод расширения, должен быть non-generic, static и non-nested
  • Каждый метод расширения должен быть static методом
  • Первый параметр метода расширения должен использовать ключевое слово this.

Ответ 2

Добавить ключевое слово static в объявление класса:

// this is a non-generic static class
public static class LinqHelper
{
}

Ответ 3

Измените его на

public static class LinqHelper

Ответ 4

Попробуйте изменить

public class LinqHelper

к

 public static class LinqHelper

Ответ 5

Обход для людей, которые испытывают ошибку, например, Натана:

У компилятора "на лету", похоже, проблема с этой ошибкой метода расширения... добавление static тоже мне не помогло.

Я хотел бы знать, что вызывает ошибку?

Но рабочий процесс состоит в том, чтобы написать новый класс расширения (не вложенный) даже в том же файле и перестроить.

Понял, что эта нить получает достаточное количество просмотров, которое стоит передать (ограниченное) решение, которое я нашел. Большинство людей, вероятно, пытались добавить "статический", прежде чем google-ing для решения! и я не видел, чтобы это исправление работало где-нибудь еще.

Ответ 6

Метод расширения должен находиться внутри статического класса. Поэтому добавьте метод расширения внутри статического класса.

так, например, это должно быть как

public static class myclass
    {
        public static Byte[] ToByteArray(this Stream stream)
        {
            Int32 length = stream.Length > Int32.MaxValue ? Int32.MaxValue : Convert.ToInt32(stream.Length);
            Byte[] buffer = new Byte[length];
            stream.Read(buffer, 0, length);
            return buffer;
        }

    }