Методы расширения должны быть определены в неэквивалентном статическом классе
Я получаю сообщение об ошибке:
Методы расширения должны быть определены в неэквивалентном статическом классе
В строке:
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;
}
}