Метод Observable.Where TSource> (IObservable<TSource>, Func<TSource, Boolean>)<
Фильтрует элементы наблюдаемой последовательности на основе предиката.
Пространство имен:System.Reactive.Linq
Сборки: System.Reactive (в System.Reactive.dll)
Синтаксис
'Declaration
<ExtensionAttribute> _
Public Shared Function Where(Of TSource) ( _
source As IObservable(Of TSource), _
predicate As Func(Of TSource, Boolean) _
) As IObservable(Of TSource)
'Usage
Dim source As IObservable(Of TSource)
Dim predicate As Func(Of TSource, Boolean)
Dim returnValue As IObservable(Of TSource)
returnValue = source.Where(predicate)
public static IObservable<TSource> Where<TSource>(
this IObservable<TSource> source,
Func<TSource, bool> predicate
)
[ExtensionAttribute]
public:
generic<typename TSource>
static IObservable<TSource>^ Where(
IObservable<TSource>^ source,
Func<TSource, bool>^ predicate
)
static member Where :
source:IObservable<'TSource> *
predicate:Func<'TSource, bool> -> IObservable<'TSource>
JScript does not support generic types and methods.
Параметры типа
- TSource
Источник типа.
Параметры
- source
Тип: System.IObservable<TSource>
Наблюдаемая последовательность, элементы которой необходимо фильтровать.
- predicate
Тип: System.Func<TSource, Boolean>
Функция для проверки каждого исходного элемента на наличие условия.
Возвращаемое значение
Тип: System.IObservable<TSource>
Наблюдаемая последовательность, содержащая элементы входной последовательности, удовлетворяющие условию.
Примечание об использовании
В Visual Basic и C# этот метод можно вызвать как метод экземпляра для любого объекта типа IObservable<TSource>. При вызове метода для экземпляра следует опускать первый параметр. Дополнительные сведения см. в разделе или .
Комментарии
Оператор Where позволяет определить функцию предиката для тестирования каждого элемента в последовательности. Каждый элемент из исходной последовательности, которая приводит к тому, что функция предиката возвращает значение false, фильтруется из результирующей последовательности.
Примеры
В следующем примере используется оператор Where с языковым запросом (LINQ) для фильтрации целочисленной последовательности таким образом, чтобы для последовательности были созданы только четные целые числа.
using System;
using System.Reactive.Linq;
namespace Example
{
class Program
{
static void Main()
{
//*********************************************************************************************//
//*** The mainSequence produces a new long integer from the Interval operator every sec. ***//
//*********************************************************************************************//
var mainSequence = Observable.Interval(TimeSpan.FromSeconds(1));
//*********************************************************************************************//
//*** This LINQ statement uses the Where operator to filter the integers in the sequence so ***//
//*** that only the even integers are returned. ***//
//*** ***//
//*** you could also call the method explicitly. For example... ***//
//*** ***//
//*** var seqWhereEven = mainSequence.Where(x => x % 2 == 0); ***//
//*** ***//
//*********************************************************************************************//
var seqWhereEven = from i in mainSequence
where i % 2 == 0
select i;
//*********************************************************************************************//
//*** Create a subscription and write each of the even integers to the console window. ***//
//*********************************************************************************************//
seqWhereEven.Subscribe(x => Console.WriteLine(x));
Console.ReadLine();
}
}
}
Приведенные ниже выходные данные были созданы в примере кода.
0
2
4
6
8
10
12
14
16