Enumerable.SkipWhile 메서드

정의

지정된 조건이 true이면 시퀀스에 있는 요소를 무시하고 나머지 요소를 반환합니다.

오버로드

SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>)

지정된 조건이 true이면 시퀀스에 있는 요소를 무시하고 나머지 요소를 반환합니다.

SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>)

지정된 조건이 true이면 시퀀스에 있는 요소를 무시하고 나머지 요소를 반환합니다. 조건자 함수의 논리에 요소의 인덱스가 사용됩니다.

SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>)

Source:
Skip.cs
Source:
Skip.cs
Source:
Skip.cs

지정된 조건이 true이면 시퀀스에 있는 요소를 무시하고 나머지 요소를 반환합니다.

public static System.Collections.Generic.IEnumerable<TSource> SkipWhile<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,bool> predicate);

형식 매개 변수

TSource

source 요소의 형식입니다.

매개 변수

source
IEnumerable<TSource>

요소를 반환할 IEnumerable<T>입니다.

predicate
Func<TSource,Boolean>

각 요소를 조건에 대해 테스트하는 함수입니다.

반환

IEnumerable<TSource>

입력 시퀀스에서 predicate에 지정된 테스트를 통과하지 않는 급수의 첫 요소부터 시작되는 요소가 들어 있는 IEnumerable<T>입니다.

예외

source 또는 predicatenull인 경우

예제

다음 코드 예제에서는 조건이 true인 경우 를 사용하여 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>) 배열의 요소를 건너뛰는 방법을 보여 줍니다.

int[] grades = { 59, 82, 70, 56, 92, 98, 85 };

IEnumerable<int> lowerGrades =
    grades
    .OrderByDescending(grade => grade)
    .SkipWhile(grade => grade >= 80);

Console.WriteLine("All grades below 80:");
foreach (int grade in lowerGrades)
{
    Console.WriteLine(grade);
}

/*
 This code produces the following output:

 All grades below 80:
 70
 59
 56
*/

설명

메서드는 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>) 지연된 실행을 사용하여 구현됩니다. 즉시 반환 값은 작업을 수행 하는 데 필요한 모든 정보를 저장 하는 개체입니다. 이 메서드가 나타내는 쿼리는 개체를 직접 호출 GetEnumerator 하거나 C# 또는 For Each Visual Basic에서 를 사용하여 foreach 개체를 열거할 때까지 실행되지 않습니다.

이 메서드는 를 사용하여 predicatesource 각 요소를 테스트하고 결과가 true인 경우 요소를 건너뜁니다. 조건자 함수가 요소에 대해 반환 false 된 후 해당 요소와 의 나머지 요소가 source 생성되고 더 이상 호출 predicate이 없습니다.

시퀀스의 모든 요소에 대해 를 반환 true 하면 predicateIEnumerable<T> 가 반환됩니다.

SkipWhile 메서드는 TakeWhile 기능 보완입니다. 컬렉션 시퀀스와 coll 순수 함수 p가 지정된 경우 의 결과를 coll.TakeWhile(p) 연결하고 와 coll.SkipWhile(p) 동일한 시퀀스를 coll생성합니다.

Visual Basic 쿼리 식 구문에서 절은 Skip While 호출로 SkipWhile변환됩니다.

추가 정보

적용 대상

.NET 9 및 기타 버전
제품 버전
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>)

Source:
Skip.cs
Source:
Skip.cs
Source:
Skip.cs

지정된 조건이 true이면 시퀀스에 있는 요소를 무시하고 나머지 요소를 반환합니다. 조건자 함수의 논리에 요소의 인덱스가 사용됩니다.

public static System.Collections.Generic.IEnumerable<TSource> SkipWhile<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,int,bool> predicate);

형식 매개 변수

TSource

source 요소의 형식입니다.

매개 변수

source
IEnumerable<TSource>

요소를 반환할 IEnumerable<T>입니다.

predicate
Func<TSource,Int32,Boolean>

각 소스 요소를 조건에 대해 테스트할 함수이며, 이 함수의 두 번째 매개 변수는 소스 요소의 인덱스를 나타냅니다.

반환

IEnumerable<TSource>

입력 시퀀스에서 predicate에 지정된 테스트를 통과하지 않는 급수의 첫 요소부터 시작되는 요소가 들어 있는 IEnumerable<T>입니다.

예외

source 또는 predicatenull인 경우

예제

다음 코드 예제에서는 사용 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) 하는 방법을 보여 줍니다는 요소의 인덱스에 따라 달라지는 조건이 true인 경우 배열의 요소를 건너뜁니다.

int[] amounts = { 5000, 2500, 9000, 8000,
                    6500, 4000, 1500, 5500 };

IEnumerable<int> query =
    amounts.SkipWhile((amount, index) => amount > index * 1000);

foreach (int amount in query)
{
    Console.WriteLine(amount);
}

/*
 This code produces the following output:

 4000
 1500
 5500
*/

설명

이 메서드는 지연 된 실행을 사용 하 여 구현 됩니다. 즉시 반환 값은 작업을 수행 하는 데 필요한 모든 정보를 저장 하는 개체입니다. 이 메서드가 나타내는 쿼리는 개체를 직접 호출 GetEnumerator 하거나 C# 또는 For Each Visual Basic에서 를 사용하여 foreach 개체를 열거할 때까지 실행되지 않습니다.

메서드는 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) 를 사용하여 predicatesource 각 요소를 테스트하고 결과가 true인 경우 요소를 건너뜁니다. 조건자 함수가 요소에 대해 반환 false 된 후 해당 요소와 의 나머지 요소가 source 생성되고 더 이상 호출 predicate이 없습니다.

시퀀스의 모든 요소에 대해 를 반환 true 하면 predicateIEnumerable<T> 가 반환됩니다.

predicate 첫 번째 인수는 테스트할 요소를 나타냅니다. 두 번째 인수는 내 source요소의 인덱스(0부터 시작)를 나타냅니다.

SkipWhile 메서드는 TakeWhile 기능 보완입니다. 컬렉션 시퀀스와 coll 순수 함수 p가 지정된 경우 의 결과를 coll.TakeWhile(p) 연결하고 와 coll.SkipWhile(p) 동일한 시퀀스를 coll생성합니다.

Visual Basic 쿼리 식 구문에서 절은 Skip While 호출로 SkipWhile변환됩니다.

추가 정보

적용 대상

.NET 9 및 기타 버전
제품 버전
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0