[C#/ASP.NET]List<>中Sort()、Find()、FindAll()、Exist()的使用方法

简介: [C#/ASP.NET]中List真的非常好用。一个例子简单说明一下List中Sort()、Find()、FindAll()、Exist()的使用方法简单介绍:List.Sort() → 排序TList.

[C#/ASP.NET]中List<T>真的非常好用。一个例子简单说明一下List<>中Sort()、Find()、FindAll()、Exist()的使用方法


简单介绍:


List<T>.Sort() → 排序T


List<T>.Find() → 找出一個T


List<T>.FindAll() →找出多個T


List<T>.Exist() →判斷T是否存在


示例代码:


页面文件GenericList.aspx





?






1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18


<%@ Page
Language=
"C#" AutoEventWireup= "true" CodeFile= "GenericList.aspx.cs" Inherits= "GenericList" %>


<!DOCTYPE
html PUBLIC
"-//W3C//DTD XHTML 1.0
Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >


<html
xmlns=
"http://www.w3.org/1999/xhtml" >

<head
runat=
"server" >

    <title>GenericList</title>

</head>

<body>

    <form
id=
"form1" runat= "server" >

    <div>

        原始資料:

        <asp:GridView
ID=
"GridView1" runat= "server" >

        </asp:GridView>

    </div>

    </form>

</body>

</html>

后台代码文件GenericList.aspx.cs





?






1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102


using
System;

using
System.Collections.Generic;

using
System.Web;

using
System.Web.UI;

using
System.Web.UI.WebControls;


public
partial class GenericList :
System.Web.UI.Page

{


    protected
void Page_Load( object
sender, EventArgs e)

    {

        List<Person> lstPerson = new List<Person>();

        lstPerson.Add( new Person(1,
"puma" ,
10));

        lstPerson.Add( new Person(2,
"F6 Team" ,
20));

        lstPerson.Add( new Person(3,
"ASP.NET" ,
30));

        lstPerson.Add( new Person(4,
"Dotblogs" ,
40));


        //原始資料顯示在GridView上

        this .GridView1.DataSource = lstPerson;

        this .GridView1.DataBind();




        //List<T>.Find()

        //找出Name='puma'的Person

        Response.Write( "找出Name='puma'的Person→ " );

        Response.Write(lstPerson.Find( delegate (Person p) {
return p.Name == "puma" ; }).ToString() +
"<p>" );




        //List<T>.FindAll()

        //找出Age>10的數目

        Response.Write( "找出Age>10的數目→ " );

        Response.Write(lstPerson.FindAll( delegate (Person p) {
return p.Age > 10; }).Count.ToString() + "<p>" );




        //List<T>.Exists()

        //檢查Name='F6'是否存在

        Response.Write( "檢查Name='F6'是否存在→ " );

        Response.Write(lstPerson.Exists( delegate (Person p) {
return p.Name == "F6" ; }).ToString() +
"<p>" );




        //List<T>.Sort()

        //依Name升冪排序

        Response.Write( "<p>依Name升冪排序↑<br/>" );

        lstPerson.Sort( delegate (Person p1,
Person p2) {
return Comparer< string >.Default.Compare(p1.Name, p2.Name); });

        foreach
(Person p in lstPerson)

        {

            Response.Write(p.ToString() + "<br/>" );

        }




        //List<T>.Sort()

        //依Name降冪排序

        Response.Write( "<p>依Name降冪排序↓<br/>" );

        lstPerson.Sort( delegate (Person p1,
Person p2) {
return Comparer< string >.Default.Compare(p2.Name, p1.Name); });

        foreach
(Person p in lstPerson)

        {

            Response.Write(p.ToString() + "<br/>" );

        }

    }

}


public class
Person

{

    private
int _ID;

    private
string _Name;

    private
int _Age;


    public
Person( int
ID, string
Name, int
Age)

    {

        _ID = ID;

        _Name = Name;

        _Age = Age;

    }


    public
int ID

    {

        set
{ _ID = value; }

        get
{ return
_ID; }

    }


    public
string Name

    {

        set
{ _Name = value; }

        get
{ return
_Name; }

    }


    public
int Age

    {

        set
{ _Age = value; }

        get
{ return
_Age; }

    }


    public
override string ToString()

    {

        return
string .Format( "ID:{0},Name:{1},Age:{2}" , _ID, _Name, _Age);

    }

}

 

执行结果:

转自:http://www.cnblogs.com/ATree/archive/2011/02/25/Asp-Net_List_Sort_Find_FindAll_Exist.html

目录
相关文章
|
1月前
|
Java 物联网 C#
C#/.NET/.NET Core学习路线集合,学习不迷路!
C#/.NET/.NET Core学习路线集合,学习不迷路!
|
3天前
|
开发框架 监控 .NET
C#进阶-ASP.NET WebForms调用ASMX的WebService接口
通过本文的介绍,希望您能深入理解并掌握ASP.NET WebForms中调用ASMX WebService接口的方法和技巧,并在实际项目中灵活运用这些技术,提高开发效率和应用性能。
22 5
|
11天前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
57 13
|
1月前
|
Java 物联网 编译器
C#一分钟浅谈:.NET Core 与 .NET 5 区别
本文对比了 .NET Core 和 .NET 5,从历史背景、主要区别、常见问题及易错点等方面进行了详细分析。.NET Core 侧重跨平台支持和高性能,而 .NET 5 在此基础上统一了 .NET 生态系统,增加了更多新特性和优化。开发者可根据具体需求选择合适的版本。
47 7
|
1月前
|
人工智能 开发框架 前端开发
C#/.NET/.NET Core技术前沿周刊 | 第 12 期(2024年11.01-11.10)
C#/.NET/.NET Core技术前沿周刊 | 第 12 期(2024年11.01-11.10)
|
1月前
|
开发框架 网络协议 .NET
C#/.NET/.NET Core优秀项目和框架2024年10月简报
C#/.NET/.NET Core优秀项目和框架2024年10月简报
|
19天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
19天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
29天前
|
人工智能 开发框架 安全
C#/.NET/.NET Core技术前沿周刊 | 第 13 期(2024年11.11-11.17)
C#/.NET/.NET Core技术前沿周刊 | 第 13 期(2024年11.11-11.17)
|
1月前
|
网络协议 Unix Linux
精选2款C#/.NET开源且功能强大的网络通信框架
精选2款C#/.NET开源且功能强大的网络通信框架