导出 (0) 打印
全部展开
此文章由机器翻译。 将光标移到文章的句子上,以查看原文。 更多信息。
译文
原文

Enumerable.SkipWhile<TSource> 方法 (IEnumerable<TSource>, Func<TSource, Boolean>)

只要满足指定的条件,就跳过序列中的元素,然后返回剩余元素。

命名空间:  System.Linq
程序集:  System.Core(在 System.Core.dll 中)

public static IEnumerable<TSource> SkipWhile<TSource>(
	this IEnumerable<TSource> source,
	Func<TSource, bool> predicate
)

类型参数

TSource

source 中的元素的类型。

参数

source
类型:System.Collections.Generic.IEnumerable<TSource>
一个 IEnumerable<T>,用于从中返回元素。
predicate
类型:System.Func<TSource, Boolean>
用于测试每个元素是否满足条件的函数。

返回值

类型:System.Collections.Generic.IEnumerable<TSource>
一个 IEnumerable<T>,包含输入序列中的元素,该输入序列从线性系列中没有通过 predicate 指定测试的第一个元素开始。

使用说明

在 Visual Basic 和 C# 中,可以在 IEnumerable<TSource> 类型的任何对象上将此方法作为实例方法来调用。当使用实例方法语法调用此方法时,请省略第一个参数。有关详细信息,请参阅扩展方法 (Visual Basic)扩展方法(C# 编程指南)

异常条件
ArgumentNullException

sourcepredicatenull

通过使用延迟执行实现 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 方法。 即时返回值为一个对象,该对象存储执行操作所需的所有信息。 只有通过直接调用对象的 GetEnumerator 方法或使用 Visual C# 中的 foreach(或 Visual Basic 中的 For Each)来枚举该对象时,才执行此方法表示的查询。

此方法使用 predicate 测试 source 的每个元素,如果结果为 true,则跳过该元素。 谓词函数针对一个元素返回 false 后,则生成该元素及 source 中的剩余元素,并且不再调用 predicate

如果 predicate 为序列中的所有元素返回 true,则返回一个空 IEnumerable<T>

TakeWhile SkipWhile 方法在功能上补充。 如果给定一个序列 coll 和一个纯函数 p,则连接 coll.TakeWhile(p)coll.SkipWhile(p) 的结果会生成与 coll 相同的序列。

在 Visual Basic 查询表达式语法中,Skip While 子句转换为 SkipWhile 的一个调用。

下面的代码示例演示如何使用 SkipWhile<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 在条件为 true 的情况下跳过数组的元素。


            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
            */



.NET Framework

受以下版本支持:4.5.2、4.5.1、4.5、4、3.5

.NET Framework Client Profile

受以下版本支持:4、3.5 SP1

可移植类库

受以下版本支持:可移植类库

适用于 Windows 应用商店应用的 .NET

受以下版本支持:Windows 8

适用于 Windows Phone 应用的 .NET

受以下版本支持:Windows Phone 8、Silverlight 8.1

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008(不支持服务器核心角色), Windows Server 2008 R2(支持带 SP1 或更高版本的服务器核心角色;不支持 Itanium)

.NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参阅.NET Framework 系统要求

社区附加资源

添加
显示:
© 2014 Microsoft