【C# 基础精讲】List 集合的使用

news2024/12/23 23:06:26

在这里插入图片描述

在C#中,List<T>是一种非常常用的泛型集合类,用于存储一组相同类型的元素。List<T>具有动态调整大小的能力,可以方便地添加、删除、查找和修改元素,非常灵活和高效。本文将详细介绍List<T>集合的使用方法,包括创建List<T>对象、添加元素、删除元素、查找元素、遍历集合以及常用的List<T>方法等内容。

1. 创建List<T>对象

要使用List<T>,需要引入System.Collections.Generic命名空间。创建List<T>对象时,需要指定集合中元素的类型T

using System.Collections.Generic;

// 创建一个整数列表
List<int> numbersList = new List<int>();

在上述代码中,我们创建了一个List<int>类型的整数列表numbersList

2. 添加元素

List<T>提供了多个方法用于添加元素到列表中,最常用的是Add()方法。

List<string> fruitsList = new List<string>();

// 添加元素到列表
fruitsList.Add("apple");
fruitsList.Add("orange");
fruitsList.Add("banana");

在上述代码中,我们创建了一个List<string>类型的字符串列表fruitsList,然后使用Add()方法添加了三个水果元素到列表中。

3. 删除元素

List<T>提供了多个方法用于删除元素,常用的有Remove()RemoveAt()Clear()方法。

Remove()方法

Remove()方法用于从列表中删除指定元素。如果列表中存在多个相同的元素,只会删除第一个匹配的元素。

List<string> fruitsList = new List<string> { "apple", "orange", "banana" };
fruitsList.Remove("orange"); // 从列表中删除元素"orange"

在上述代码中,Remove("orange")会删除列表fruitsList中的第一个元素"orange"。

RemoveAt()方法

RemoveAt()方法用于根据索引从列表中删除元素。

List<string> fruitsList = new List<string> { "apple", "orange", "banana" };
fruitsList.RemoveAt(1); // 从列表中删除索引为1的元素,即"orange"

在上述代码中,RemoveAt(1)会删除列表fruitsList中索引为1的元素"orange"。

Clear()方法

Clear()方法用于清空整个列表,即删除所有元素。

List<string> fruitsList = new List<string> { "apple", "orange", "banana" };
fruitsList.Clear(); // 清空列表

在上述代码中,Clear()会将列表fruitsList中的所有元素全部删除,列表变为空。

4. 查找元素

List<T>提供了多个方法用于查找元素,常用的有Contains()IndexOf()方法。

Contains()方法

Contains()方法用于判断列表中是否包含指定元素,返回一个布尔值。

List<string> fruitsList = new List<string> { "apple", "orange", "banana" };
bool isContains = fruitsList.Contains("orange"); // 判断列表是否包含元素"orange"

在上述代码中,isContains将会被赋值为true,因为列表fruitsList中包含元素"orange"。

IndexOf()方法

IndexOf()方法用于查找指定元素在列表中的索引,如果列表中存在多个相同的元素,只返回第一个匹配的元素索引。

List<string> fruitsList = new List<string> { "apple", "orange", "banana" };
int index = fruitsList.IndexOf("orange"); // 查找元素"orange"的索引

在上述代码中,index将会被赋值为1,表示元素"orange"在列表fruitsList中的索引为1。

5. 遍历List<T>

可以使用循环结构(如forforeach)遍历List<T>中的所有元素。

使用for循环遍历

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };

// 使用for循环遍历列表
for (int i = 0; i < numbersList.Count; i++)
{
    Console.WriteLine(numbersList[i]);
}

在上述代码中,for循环从0开始遍历到numbersList.Count - 1,依次输出列表中的每个元素。

使用foreach循环遍历

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };

// 使用foreach循环遍历列表
foreach (int number in numbersList)
{
    Console.WriteLine(number);
}

在上述代码中,foreach循环遍历numbersList列表中的每个元素,并将元素的值赋给变量number,然后输出number的值。

6. List<T>常用方法

除了上述介绍的方法外,List<T>还提供了许多其他常用的方法,方便对集合进行操作。下面列举一些常用的方法:

Count

Count属性用于获取列表中元素的个数。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
int count = numbersList.Count; // 获取列表中元素的个数,此处为5

在上述代码中,count将会被赋值为5,表示列表numbersList中有5个元素。

Sort

Sort()方法用于对列表中的元素进行排序。

List<int> numbersList = new List<int> { 5, 2, 8, 1, 9 };
numbersList.Sort(); // 对列表中的元素进行排序

在上述代码中,numbersList列表将会被排序为 { 1, 2, 5, 8, 9 }

Reverse

Reverse()方法用于反转列表中元素的顺序。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
numbersList.Reverse(); // 反转列表中元素的顺序

在上述代码中,numbersList列表将会被反转为 { 5, 4, 3, 2, 1 }

FindFindAll

Find()方法用于查找符合指定条件的第一个元素,返回满足条件的第一个元素,如果没有找到,则返回默认值。FindAll()方法用于查找符合指定条件的所有元素,返回一个新的List<T>列表。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
int evenNumber = numbersList.Find(x => x % 2 == 0); // 查找第一个偶数元素
List<int> oddNumbers = numbersList.FindAll(x => x % 2 != 0); // 查找所有奇数元素

在上述代码中,evenNumber将会被赋值为2,oddNumbers将会是一个新的List<int>列表,包含所有的奇数元素。

RemoveAll

RemoveAll()方法用于根据指定条件删除所有符合条件的元素。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
numbersList.RemoveAll(x => x % 2 == 0); // 删除所有偶数元素

在上述代码中,numbersList列表将会删除所有的偶数元素,变为 { 1, 3, 5 }

ForEach

ForEach()方法用于对列表中的每个元素执行指定的操作。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
numbersList.ForEach(x => Console.WriteLine(x * 2)); // 将列表中的每个元素乘以2并输出

在上述代码中,ForEach()方法将列表中的每个元素都乘以2,并输出结果。

Exists

Exists()方法用于判断列表中是否存在符合指定条件的元素,返回一个布尔值。

List<int> numbersList = new List<int> { 1, 2, 3, 4, 5 };
bool isExists = numbersList.Exists(x => x > 3); // 判断是否存在大于3的元素

在上述代码中,isExists将会被赋值为true,因为列表numbersList中存在大于3的元素。

7. List<T>与数组的比较

在C#编程中,我们常常需要在集合中存储一组相同类型的数据。在选择使用List<T>还是数组时,需要根据实际需求来做出合理的选择。

数组的优点和适用场景

  • 性能更好: 数组在内存中是连续分配的,因此访问元素的性能更好,尤其是对于大量元素的访问。
  • 固定长度: 数组的长度一旦确定,就无法更改,这有助于保证数据的稳定性和安全性。
  • 多维数组: 数组支持多维数组,可以用于表示表格、矩阵等结构。

适用场景:当数据集合长度固定且需要频繁访问元素时,可以考虑使用数组。

List<T>的优点和适用场景

  • 动态调整大小: List<T>可以根据需要动态调整大小,无需提前指定长度,更加灵活。
  • 方便的添加和删除: List<T>提供了丰富的方法用于添加、删除和修改元素,操作更方便。
  • 适应不确定数据量: 当数据集合长度不确定,可能需要频繁添加或删除元素时,可以使用List<T>

适用场景:当数据集合长度不确定,或需要频繁进行添加、删除等操作时,可以考虑使用List<T>

8. 总结

List<T>是C#编程中非常常用的泛型集合类,用于存储一组相同类型的元素。本文介绍了List<T>的创建、添加、删除、查找和遍历等基本操作,以及常用的List<T>方法。同时,我们比较了List<T>与数组的优缺点和适用场景,希望可以帮助您在实际开发中做出合理的选择。List<T>提供了更多灵活性和便利性,尤其在处理不确定数据量的情况下更为常用。祝您在C#编程中灵活使用List<T>,编写出高效、可维护的代码!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/860140.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

教你如何实现接口防刷

教你如何实现接口防刷 前言 我们在浏览网站后台的时候&#xff0c;假如我们频繁请求&#xff0c;那么网站会提示 “请勿重复提交” 的字样&#xff0c;那么这个功能究竟有什么用呢&#xff0c;又是如何实现的呢&#xff1f; 其实这就是接口防刷的一种处理方式&#xff0c;通…

一台电脑B用网线共享另外一台电脑A的WiFi网络,局域网其它电脑C怎么访问电脑B服务

环境: 电脑A:联想E14笔记本 系统:WIN10 专业版 局域网IP:192.168.14.111 共享IP:192.168.137.1 电脑B:HP 288pro 台式机 Ubuntu20.04 系统:共享IP:192.168.137.180 电脑A正常连接WIFI,电脑B没有WIFI只有,有线网口,共享电脑A的无线网 (还有一种桥接网络不在本…

[FPAG开发]使用Vivado创建第一个程序

1 打开Vivado软件&#xff0c;新建项目 选择一个纯英文路径 选择合适的型号 产品型号ZYNQ-7010xc7z010clg400-1ZYNQ-7020xc7z010clg400-2 如果型号选错&#xff0c;可以单击这里重新选择 2 创建工程源文件 可以看到文件创建成功 双击文件打开&#xff0c;插入代码 modul…

腾讯云轻量服务器和云服务器的CPU处理器有差别吗?

腾讯云轻量应用服务器和CVM云服务器的CPU处理器性能有差别吗&#xff1f;创建轻量应用服务器时不支持指定底层物理服务器的CPU型号&#xff0c;腾讯云将随机分配满足套餐规格的物理CPU型号&#xff0c;通常优先选择较新代次的CPU型号。而云服务器CVM的CPU处理器型号、主频都是有…

数据库--MySQL

一、什么是范式&#xff1f; 范式是数据库设计时遵循的一种规范&#xff0c;不同的规范要求遵循不同的范式。 最常用的三大范式 第一范式(1NF)&#xff1a;属性不可分割&#xff0c;即每个属性都是不可分割的原子项。(实体的属性即表中的列) 第二范式(2NF)&#xff1a;满足…

elementui表格数据加载即勾选

搜索关键字&#xff1a;elementui表格数据加载即勾选|elementui表格勾选 1、关键点&#xff1a; 需要使用watch和nextTick,直接参考官方案例&#xff0c;在数据返回时候设置勾选不好使。 2、表格定义 <el-table :height"570" :data"roleTableData" st…

小疆智控EtherCAT转PROFINET连接零差云控驱动器接入Profinet网络

西门子S7-1200/1500系列的PLC&#xff0c;需要连接带EtherCAT的通讯功能的伺服驱动器等设备。西门子的PLC采用PROFINET实时以太网通讯协议&#xff0c;要连接EtherCAT的设备&#xff0c;就必须进行通讯协议转换。小疆GW-PN-ECATM系列的网关提供了&#xff0c;快速可行的解决方案…

FreeRTOS( 任务与中断优先级,临界保护)

资料来源于硬件家园&#xff1a;资料汇总 - FreeRTOS实时操作系统课程(多任务管理) 目录 一、中断优先级 1、NVIC基础知识 2、FreeRTOS配置NVIC 3、SVC、PendSV、Systick中断 4、不受FreeRTOS管理的中断 5、STM32CubeMX配置 二、任务优先级 1、任务优先级说明 2、任务…

打破音频语言障碍,英语音频翻译成文字软件助你畅快对话

要理解外语歌曲对我来说难如登天。不过&#xff0c;这种痛苦没有持续太久&#xff0c;我发现了一种音频翻译技术&#xff0c;它像一个语言转换器&#xff0c;可以即时将外语歌曲翻译成我听得懂的语言&#xff01;我惊喜地试用后&#xff0c;终于可以在听歌的同时看到翻译的歌词…

跳跃游戏——力扣55

文章目录 题目描述解法一 贪心题目描述 解法一 贪心 bool canJump(vector<int>& nums){int n=nums.

Docker安装Hadoop分布式集群

一、准备环境 docker search hadoop docker pull sequenceiq/hadoop-docker docker images二、Hadoop集群搭建 1. 运行hadoop102容器 docker run --name hadoop102 -d -h hadoop102 -p 9870:9870 -p 19888:19888 -v /opt/data/hadoop:/opt/data/hadoop sequenceiq/hadoop-do…

战术的勤奋,弥补不了战略的重大缺陷

战术的勤奋&#xff0c;弥补不了战略的大缺陷 战略的懒惰&#xff0c;遍地都是 王兴说过&#xff1a;人为了逃避思考可以干任何事 趣讲大白话&#xff1a;局部优秀&#xff0c;改变不了整体 【趣讲信息科技252期】 **************************** 中小企业顶顶层设计薄弱 这也是…

【笔试训练】统计回文

一、单选 1、以下代码结果是什么&#xff08;&#xff09; public class foo {public static void main(String sgf[]) {StringBuffer anew StringBuffer("A");StringBuffer bnew StringBuffer("B");operate(a,b);System.out.println(a"."b);}st…

Python IDE

Python IDE 本文为大家推荐几款款不错的 Python IDE&#xff08;集成开发环境&#xff09;&#xff0c;比较推荐 PyCharm&#xff0c;当然你可以根据自己的喜好来选择适合自己的 Python IDE。 PyCharm PyCharm 是由 JetBrains 打造的一款 Python IDE。 PyCharm 具备一般 Pyt…

plsql设置id自增

plsql如何设置id自增 首先先创表。创建序列创建触发器 首先先创表。 在目录(tables)中选择新建&#xff1a;我创建的表明为SYS_TEST 创建序列 在目录sequences选择新建,我创建的名称为SYS_TEST_SEQ 在点击下方的应用即可。 创建触发器 在目录Triggers选择新建&#xff…

UML-类图和对象图

目录 类图概述&#xff1a; 1.类: 2.属性: 3.类的表示&#xff1a; 4.五种方法: 类图的关系&#xff1a; 1.关联 2.聚合 3.组合 4.依赖 5.泛化 6.实现 对象图概述&#xff1a; 1. 对象图包含元素: 2. 什么是对象 3.对象的状态可以改变: 4.对象的行为 5.对象标…

差值结构的测地线

( A, B )---2*30*2---( 1, 0 )( 0, 1 ) 让网络的输入只有2个节点&#xff0c;AB训练集各由7张二值化的图片组成&#xff0c;让A和B中都只有1个1&#xff0c;统计迭代次数并排序。 其中有7组数据 差值结构 A-B 迭代次数 1 2 1 1*0*0*0*0*0*0-2*0*0*0*0*0*0 98040.54 - …

【Apollo】Apollo-ros版本架构学习与源码分析

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Apollo-ros版本架构学习与源码分析。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&a…

javaee dom4j读取xml文件

引入jar包 dom4j-1.6.1.jar 创建xml文件 <?xml version"1.0" encoding"UTF-8"?> <books><book id"1"><title ID"t1">背影</title><price>88</price><author>三毛</author>…

【C++】二叉搜索树的模拟实现(K,KV树)递归与非递归方式

文章目录 前言一、K树1.结点的定义2.构造函数3.拷贝构造函数4.赋值运算符重载5.析构函数6.二叉搜索树的查找&#xff08;find&#xff09;1.非递归2.递归 7.二叉搜索树的插入&#xff08;Insert&#xff09;1.非递归2.递归 8.二叉搜素树的删除&#xff08;Erase&#xff09;1.非…