当前位置:   article > 正文

C# List使用详解

C# List使用详解

在 C# 中,List 和数组都是用于存储一组元素的数据结构,但它们之间有一些关键的区别和各自的优缺点。

数组(Array)的特点:

  1. 静态大小: 数组在创建时需要指定大小,且大小不能更改。例如,int[] numbers = new int[3]; 创建了一个包含3个整数的数组。

  2. 类型固定: 数组中的元素类型是固定的,无法在运行时更改。

  3. 直接访问元素: 数组提供了通过索引直接访问元素的方式,例如,int value = numbers[1];

  4. 性能: 由于数组大小固定,可以在内存中分配连续的空间,因此在某些情况下可能具有更好的性能。

List 的特点:

  1. 动态大小: List 是动态数组,可以根据需要动态调整大小,通过 AddRemove 等方法进行操作。

  2. 泛型支持: List 是泛型集合,可以存储任意类型的元素,例如,List<int> numbers = new List<int>();

  3. 灵活性: 提供了丰富的方法和属性,如 AddRemoveCount 等,使操作更加灵活。

  4. 类型灵活: List 可以存储不同类型的元素,而数组中的元素类型是固定的。

比较:

  • 灵活性: List 更灵活,可以根据需要动态调整大小,而数组的大小是固定的。

  • 类型灵活性: List 可以存储不同类型的元素,而数组要求所有元素是相同类型的。

  • 性能: 数组在某些情况下可能具有更好的性能,因为它们在内存中分配连续的空间,而 List 的元素可能分散在堆上的不同位置。

  • 直接访问 vs 方法调用: 数组通过索引直接访问元素,而 List 则需要通过方法调用来进行操作。

总体而言,如果需要静态大小和直接访问元素,并且元素类型相同且固定,数组可能更合适。如果需要动态大小、灵活性和可以存储不同类型的元素,List 则是更好的选择。在实际应用中,选择取决于具体的需求和性能要求。

List使用以及嵌套使用

  1. using System;
  2. using System.Collections.Generic;
  3. class Program
  4. {
  5. static void Main()
  6. {
  7. // 创建一个整数类型的 List
  8. List<int> numbers = new List<int>();
  9. // 添加元素
  10. numbers.Add(10);
  11. numbers.Add(20);
  12. numbers.Add(30);
  13. // 遍历 List
  14. Console.WriteLine("List中的元素:");
  15. foreach (int num in numbers)
  16. {
  17. Console.WriteLine(num);
  18. }
  19. }
  20. }

C# 嵌套数组的基本用法:

  1. using System;
  2. class Program
  3. {
  4. static void Main()
  5. {
  6. // 创建一个二维数组
  7. int[,] matrix = new int[3, 3] { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 9 } };
  8. // 访问二维数组中的元素
  9. Console.WriteLine("二维数组中的元素:");
  10. for (int i = 0; i < 3; i++)
  11. {
  12. for (int j = 0; j < 3; j++)
  13. {
  14. Console.Write(matrix[i, j] + " ");
  15. }
  16. Console.WriteLine();
  17. }
  18. // 创建一个包含数组的 List
  19. List<int[]> nestedList = new List<int[]>
  20. {
  21. new int[] { 1, 2, 3 },
  22. new int[] { 4, 5, 6 },
  23. new int[] { 7, 8, 9 }
  24. };
  25. // 遍历 List 中的数组
  26. Console.WriteLine("List中嵌套数组的元素:");
  27. foreach (int[] array in nestedList)
  28. {
  29. foreach (int num in array)
  30. {
  31. Console.Write(num + " ");
  32. }
  33. Console.WriteLine();
  34. }
  35. }
  36. }

List数组添加删除

在C#中,使用List和数组处理指令(如添加、删除等操作)的方法略有不同。让我为你详细解释一下:

使用数组处理指令:

假设你有一个名为numbers的整数数组:

int[] numbers = new int[3];

添加元素时,你需要手动确保数组大小不会超出预设大小。例如,要添加一个新元素,你需要创建一个新的数组,并将旧数组的元素复制到新数组中,然后将新元素添加到新数组中。

  1. int[] newArray = new int[numbers.Length + 1];
  2. Array.Copy(numbers, newArray, numbers.Length);
  3. newArray[numbers.Length] = newValue;
  4. numbers = newArray;

删除元素时,你需要将要删除的元素之后的所有元素向前移动一个位置,并将最后一个元素置为默认值(对于整数而言,通常为0),或者创建一个新数组来存储不包含要删除元素的数组。

  1. // 移除索引为index的元素
  2. for (int i = index; i < numbers.Length - 1; i++)
  3. {
  4. numbers[i] = numbers[i + 1];
  5. }
  6. Array.Resize(ref numbers, numbers.Length - 1);

使用List处理指令:

假设你有一个名为numbersList的List:

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

添加元素时,你可以直接调用Add方法来添加元素:

numbersList.Add(newValue);

删除元素时,你可以直接调用Remove方法或者使用索引进行删除:

  1. numbersList.Remove(valueToRemove); // 根据值删除元素
  2. numbersList.RemoveAt(indexToRemove); // 根据索引删除元素

比较:

  • 添加操作: 使用List更简单直接,无需手动管理数组大小。
  • 删除操作: 同样,List提供了更方便的方法来删除元素,无需手动移动其他元素。
  • 性能: 在大量添加和删除元素时,List可能会更有效率,因为它能够动态调整大小并在内部管理元素的位置。
  • 使用复杂度: List的方法更直接易懂,而数组需要手动管理大小和元素位置,更容易出错。

综上所述,对于处理指令(如添加、删除等操作),List通常更为方便和高效。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/228891
推荐阅读
相关标签
  

闽ICP备14008679号

        
cppcmd=keepalive&