当前位置:   article > 正文

C#初级——List 容器_c# 初始化list容器

c# 初始化list容器

容器

在C#中,容器通常指的是用于存储和组织数据的集合类。

本文介绍的容器是动态数组List<T>  内部使用数组来存储元素,当添加元素超出当前数组容量时,会自动调整大小(扩容)。

list容器 

List<>是 C# 中的泛型集合容器,全称为 List<T>,其中 <T> 表示类型参数,允许你指定存储在列表中的元素的类型。List<T> 提供了丰富的方法和属性来操作集合中的元素,包括添加、删除和搜索等。

创建List列表

List<要存放的数据类型> List列表名 = new List<要存放的数据类型>();

List<int> listNum = new List<int>();

List基本操作

添加元素 Add()

  1. listNum.Add(1);
  2. listNum.Add(2);
  3. listNum.Add(3);
  4. listNum.Add(4);
  5. listNum.Add(5);
  6. listNum.Add(5);

通过 Add 方法,将内容存储到List中去。

获取容器大小 Count

  1. int count = listNum.Count;
  2. Console.WriteLine(count); //6

访问元素 [索引]

容器名称[索引] 

            Console.WriteLine(listNum[1]);    //2

遍历元素 for和foreach

数组的两种遍历方式在List的遍历中同样适用。

  1. for (int i = 0; i < listNum.Count; i++)
  2. {
  3. Console.WriteLine(listNum[i]);
  4. }
  5. foreach (int _num in listNum)
  6. {
  7. Console.WriteLine(_num);
  8. }

 检查元素是否存在 Contains()

Contains()是一个布尔类型的方法,当相关内容存在时,返回true,不存在时,返回false。

  1. //包含
  2. if (listNum.Contains(1))
  3. {
  4. Console.WriteLine("包含1");
  5. }

拷贝元素 GetRange()

GetRange(i , j)是将一个List列表从第 i 位开始,拷贝 j 个元素到新的List列表上的方法。

下面展示将列表全拷贝到新的列表上面。

  1. List<int> listTemp = listNum.GetRange(0, listNum.Count);
  2. foreach (int _num in listTemp)
  3. {
  4. Console.WriteLine(_num);
  5. }

索引查找元素 Index()

返回第一个找到的item索引,如果没有找到就返回-1。

            int Index1 = listNum.IndexOf(5);

移除元素

移除在x位上的元素 RemoveAt(x)

  1. listNum.RemoveAt(1); //移除在第n位上的元素
  2. foreach (int _num in listNum)
  3. {
  4. Console.WriteLine(_num);
  5. }

从第x个开始,移除y个 RemoveRange(x, y)

  1. listNum.RemoveRange(1, 2); //从第几个开始,移除几个
  2. foreach (int _num in listNum)
  3. {
  4. Console.WriteLine(_num);
  5. }

清除值为x的元素 Remove(x)

  1. listNum.Remove(4);
  2. for (int i = listNum.Count; i > 0; i--)
  3. {
  4. if (listNum[i] == 5)
  5. {
  6. listNum.RemoveAt(i);
  7. }
  8. }
  9. for (int i = 0; i < listNum.Count; i++)
  10. {
  11. Console.WriteLine(listNum[i]);
  12. }

 清除所有的元素 Clear()

  1. listNum.Clear(); //清除所有的元素
  2. Console.WriteLine(listNum.Count); //0

转变数组 ToArray()

  1. int[] arrNum = listNum.ToArray(); //转换为数组
  2. for (int i = 0; i < arrNum.Length; i++)
  3. {
  4. Console.WriteLine(arrNum[i]);
  5. }

其他

Remove() 倒序循环问题

因为list是一个动态数组,并且会在Remove移除当前的元素之后改变数组大小,然后进行i++。这样就漏检查一个元素,万一这个元素也是想要移除的,就得再执行一次移除,这样很麻烦,所以,倒序循环就能规避这一点,元素一消除,索引发生改变,但是 i 之前的索引没有发生改变,所以,i 能完美的遍历所有的元素。

原本的正序循环也可以改进,将 i++ 放在else当中,当元素被移除时,i 不实现自加1操作就可以了。 

  1. listNum.Remove(4);
  2. for (int i = 0; i < listNum.Count;)
  3. {
  4. if (listNum[i] == 5)
  5. {
  6. listNum.RemoveAt(i);
  7. }
  8. else
  9. {
  10. i++;
  11. }
  12. }
  13. for (int i = listNum.Count; i > 0; i--)
  14. {
  15. if (listNum[i] == 5)
  16. {
  17. listNum.RemoveAt(i);
  18. }
  19. }

哈希值

哈希值通常指的是通过哈希函数对数据(如字符串或数字)进行处理后得到的一个固定长度的数值,这个数值通常用于快速比较和检索数据。

  1. int num = 5;
  2. int hashCode = num.GetHashCode();
  3. Console.WriteLine(hashCode);
  4. Console.WriteLine(listNum.GetHashCode());
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/944878
推荐阅读
相关标签
  

闽ICP备14008679号