Поделиться через


Метод 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

См. также:

Ссылка

Наблюдаемый класс

Где перегрузка

Пространство имен System.Reactive.Linq