关于C#泛型列表List<T>的基本用法总结

示例代码如下:
namespace samplelistt
{
  class program
  {
      static void main(string[] args)
      {
//using system.collections.generic; 命名空间中的list
//using system.collections; 命名空间中的arraylist  
//都实现了列表集合,一个是泛形集合,一个是非泛型
//下面我们将person对象加到集合中

Person p1 = new Person( “aladdin” , 20 );
Person p2 = new Person(“zhao”, 10);
Person p3 = new Person(“jacky”, 40);

//如果不制定list的容器大小,默认是0,只要有元素加入是,会自动扩展到4,如果第5个元素加入时,就变成了8,第9个加入,就成16
//可以看出,总是成倍的增长,扩展时要重新开辟内存,这样会影响效率,如果事先知道元素个数,或者可能个数,最好给个尽量大的权衡值
//我们加入3个元素,设容器大小为4.注:设为4不是指只能放4个元素,如果超出,一样也会成倍扩展,这样做只是为了尽量扩展带来的开销
List list = new List(4);

list.Add(p1);
list.Add(p2);
list.Add(p3);

//本方法是清除多于的没有用的内存空间,例:如果开辟大小为100,而我们只用了4个,其余的放着,是不是很浪费 
//本方法调用时会检查元素个数是不是占到了容器大小的90%以上,如果是,则不进行回收.
list.TrimExcess();

//ArrayList方法与List用法一样,不同的是,它是对象集合,参数是Object这样会有装箱拆箱的可能,尽量用List
//本处不再做演示

// 1 初始化集合器
// C#3.0开始,提供了初始化功能,但是并没有反应到IL代码中,在IL中,一样也是把个转化成ADD方法来调用
List l2 = new List() { 1 ,2 ,3 ,4 ,5 };

// 2 添加元素 AddRange() 本方法可以一次性添加一批对象
List lists = new List(10);
//参数是一个必须可能跌代的对象,也可是数组  
list.AddRange( new Person[] { new Person( “aladdin” ,20) , new Person(“zhao”,6)});
 

//构造传入批量参数 ,与AddRange效果一样
List mylist = new List(new Person[] { new Person( “aladdin” ,20) , new Person(“zhao”,6)});

// 3 插入元素
// 使用Insert()方法,可以在指定位置插入元素
// 例 我们在1位置插入 则最后变成了 aladdin jacky zhao..插入意思就是,这个位我占了,以前占这位的和他之后的,通通往后移一位
mylist.Insert( 1 , new Person( “jacky” , 88 ));

foreach (Person p in mylist)
{
    Console.WriteLine(p.name);
}

// 4 访问元素
// ArrayList 与 List都是提供了索引器来访问的
Console.WriteLine( “—————-访问元素————————“);

for (int i = 0; i {
    Console.WriteLine(mylist[i].name);
}
//还可以使用foreach跌代器来实现,些处不再举例

//使用Foreach方法
//public delegate void Action(T obj);例用委托做为参数  
//些处我们用呀妈Day表达式实现
Console.WriteLine( “—————–用ForEach方法输出————————“);

mylist.ForEach( param => Console.WriteLine(param.name) ) ;

// 5删除元素
//删除元素可以使用RemoveAt()直接传入索引器值
//将第一个元素直接删除
mylist.RemoveAt(0);
//也可以将要删除的元素传给Remove方法

List lists2 = new List(10);

Person per1 = new Person( “aladdin” , 100 );
Person per2 = new Person(“zhao”, 100);
Person per3 = new Person(“jacky”, 100);

lists2.Add(per1);
lists2.Add(per2);
lists2.Add(per3);

lists2.Remove(per3);

Console.WriteLine( “——-删除后的元素———“);

foreach (Person per in lists2)
{
    Console.WriteLine(per.name);
}
//从结果可以看出 名称为Jacky的元素被删除了
//下面说一下Remove方法的删除过程  
// 用IndexOf方法确定出对象的索引,然后按索引删除
// 在IndexOf方法内,首先检查元素是不是实现了IEquatable接口,如果是,就调用这个接口中的Equals方法
// 如果没有实现,则调用Object中的Equals方法比较元素(也就是址址比较)
// 以上我们删除per3,很显明显一个地址,所以被删除了 

// 下面我们改装了Person ,实现了IEquatable,在比较方法中,始终返回false , 则per3会比较失败,不会被删除
// 结果3个都在
// 如果要删除对象,最好使用索引直接删除,因为Remove方法经历了一系列过程后,最后才按索引删除!

// RemoveRange()删除一个范围
// 第一个参数 开始位置 第二个 个数
//lists2.RemoveRange( 1 , 2 );
//Console.WriteLine( “批量删除后—————-“);

//foreach (Person per in lists2)
//{
//    Console.WriteLine(per.name);
//}

// 6 搜索
// 搜索有很多种方式,可以使用IndexOf LastIndexOf FindIndex FindLasIndex Find FindLas ,如果只是查看元素存不,可以使用Exists()方法
// IndexOf() 方法 需要将一个对象做参数, 如果打到,就返回本元素在集合中的索引,如果找不到就返回-1,IndexOf还可以使用IEquatable接口来比较元素

List ls3 = new List(10);

Person person1 = new Person(“aladdin”, 100);
Person person2 = new Person(“zhao”, 100);
Person person3 = new Person(“jacky”, 100);

ls3.Add(person1);
ls3.Add(person2);
ls3.Add(person3);

// 为了使用默认的地址比较,我们把Person的接口暂时去掉
int index = ls3.IndexOf(person3);
Console.WriteLine( “per3 的索引:” + index); //2
// 还可以指定搜索范围 从第3个开始,范围长度是1
int index2 = ls3.IndexOf(person3,2,1);
Console.WriteLine(index2);
//IEquatable比较方法前面已经写过,不再举例

// FindIndex()方法是用来搜索带有一定特性的元素
// 例用委托做参数  public delegate bool Predicate(T obj);

int index3 = ls3.FindIndex(param => param.name.Equals(“jacky”));
Console.WriteLine( index3 );// 2
// FindLastIndex是从后面查第一个出现的元素,因为我们这里没有重复元素,所以体现不出他只查找一个,就停下来的效果
int index4 = ls3.FindLastIndex(p => p.name.Equals(“aladdin”));
Console.WriteLine(index4);
// Find方法与FindIndex方法用法一样,不同的是,它返回的是元素本身
Person ppp = ls3.Find( p => p.name.Equals(“jacky”)) ;
Console.WriteLine(ppp);

// 如果要查找所有的匹配元素,而不是找到第一个就停下来,就使用FindAll方法
// 我们查找所有年纪等于100的对象,3个都符合
List newList = ls3.FindAll(p => p.age == 100);

Console.WriteLine( “———-查找所有———“);

foreach (Person p in newList)
{
    Console.WriteLine(p.name);
}

// 7 排序
// List可以例用Sort方法排序,实现算法是快速排序
// 本方法有好几个重载

//public void Sort(); //只对元素实现了IComparable才能使用这个方法 ,如果实现了则,可以直接调用一次sort之后,就排好序了
//public void Sort(Comparison comparison); //我们的Person并没有实现那个接口,所以要用泛型委托当参数的方法
//public void Sort(IComparer comparer); //泛型接口当参数 public delegate int Comparison(T x, T y);
//public void Sort(int index, int count, IComparer comparer); //可以指定范围

List ls4 = new List(10);

Person person4 = new Person(“aladdin”, 100);
Person person5 = new Person(“zhao”, 33);
Person person6 = new Person(“jacky”, 44);

ls4.Add(person4);
ls4.Add(person5);
ls4.Add(person6);

ls4.Sort(MyComparFunc);
Console.WriteLine( “————-排序后的————-“);

foreach (Person p in ls4)
{
    Console.WriteLine(p.name+ p.age );
}

Console.WriteLine( “——–颠倒循序——————“);
ls4.Reverse();

foreach (Person p in ls4)
{
    Console.WriteLine(p.name+ p.age);
}

// 8 类型转换 
//可以将集合中的元素转换成任意类型的元素,比如,我们要将集合中的Person转换成为Racer对象Racer只包含名字,没有年纪
// public List ConvertAll(Converter converter);
// public delegate TOutput Converter(TInput input);  委托参数
List ls5 = ls4.ConvertAll((input) => new Racer(input.name)) ;

Console.WriteLine( “———–转换后的玩意——–“);
foreach (Racer r in ls5)
{
    Console.WriteLine(r.name);
}

// 9 只读集合
// 在创建完集合以后,肯定是可读写的,如果不是,他就不能再添加新元素了,但是,如果是认为填充完毕,不要再做修改.
// 可以使用只读集合,使用AsReadOnly方法() 返回ReadOnlyCollection类型,它与List操作是一样的,但是一但有修改集合的操作,就会刨出异常
// 他屏蔽了通常的ADD等方法

ReadOnlyCollection persss =  ls5.AsReadOnly();

Console.WriteLine(“输出只读集合”);

foreach (Racer r in persss)
{
    Console.WriteLine(r.name);
}

Console.ReadLine();

      }

//为了比较写的委托实现方法
public static  int MyComparFunc(Person p1, Person p2)
      {
if (p1.age == p2.age)
{
    return 0;
}
else if (p1.age > p2.age)
{
    return 1;
}
else
{
    return -1;
}
      }
  }

//two helper classes
 class Person//:IEquatable
  {
      public string name;
      public int age;

      public Person( string name , int age )
      {
         this.name= name;
this.age = age;
      }

      ////始终给一个False值
      //public bool Equals(Person other)
      //{
      //    return false;
      //}

  }

  class Racer
  {
      public string name;

      public Racer(string name)
      {
         this.name= name;
      }
  }
}

更多关于C#泛型列表List的基本用法总结相关文章请关注PHP中文网!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2554273.html

(0)
上一篇 2025年3月6日 07:00:29
下一篇 2025年3月6日 07:00:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • C#编程中的泛型

    .net 1.1版本最受诟病的一个缺陷就是没有提供对泛型的支持。通过使用泛型,我们可以极大地提高代码的重用度,同时还可以获得强类型的支持,避免了隐式的装箱、拆箱,在一定程度上提升了应用程序的性能。本文将系统地为大家讨论泛型,我们先从理解泛型…

    编程技术 2025年3月6日
    200
  • C#理解泛型

    简介 Visual C# 2.0 的一个最受期待的(或许也是最让人畏惧)的一个特性就是对于泛型的支持。这篇文章将告诉你泛型用来解决什么样的问题,以及如何使用它们来提高你的代码质量,还有你不必恐惧泛型的原因。 泛型是什么? 很多人觉得泛型很难…

    编程技术 2025年3月6日
    200
  • C# 泛型的约束图文详细介绍

    本文将详细介绍c# 泛型的约束:引用类型约束;值类型约束;构造函数类型约束;转换类型约束;组合约束的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧 1.引用类型约束 struct RefSample where T:class   …

    2025年3月6日 编程技术
    200
  • 泛型对golang生态的影响及未来发展

    泛型对 go 语言生态的影响及未来发展对生态系统的影响:提高可重用性,减少代码重复增强可读性,降低维护成本支持库开发,创建通用且可扩展的库未来发展:改进类型推断,减少显式指定类型参数的需要引入嵌套泛型,创建更复杂和灵活的数据结构支持泛型方法…

    2025年3月6日
    200
  • 泛型在golang中的常见错误及解决方法

    go 中泛型使用不当会导致错误:指向类型参数的指针无法解引用,应使用具体类型指针。泛型类型无法与非泛型值比较,应使用反射进行比较。滥用空接口会引起运行时错误,应使用更具体的类型参数。 Go 中泛型的常见错误及解决方法 Go 是一门被广泛使用…

    2025年3月6日
    200
  • 泛型对golang程序员有哪些好处?

    泛型对 go 程序员的好处:可重用性增强:创建通用函数和数据结构,减少重复代码。减少冗余:使用通用函数和数据结构,避免编写冗余代码。安全性提高:强制类型检查,捕获编译时错误,提升程序稳定性。代码可读性增强:使用类型变量,清晰表达功能和数据结…

    2025年3月6日
    200
  • 如何使用泛型为golang添加新特性

    go 中泛型允许创建适用于多种数据类型的代码。语法为 type name[t any] struct { … },其中 t 为泛型参数。使用 func copyslice[t any](dst, src []t) 函数展示了复制…

    2025年3月6日
    200
  • 泛型在golang中是否会被滥用?

    是,泛型在 go 中可能会被滥用,导致代码复杂性增加、性能下降和代码重复。滥用示例包括将泛型用于不同类型变量的比较或使用泛型排序算法对不同类型切片进行排序。避免滥用泛型,遵循以下准则:仅在需要时使用泛型,优先使用具体类型实现,减少泛型参数数…

    2025年3月6日
    200
  • 泛型在golang中的特殊用例和技巧

    go 中泛型的特殊用例和技巧使用空类型接口进行动态类型检查,检查运行时类型。在集合中使用泛型类型参数,创建多样化类型的容器。实现泛型方法,为不同类型的参数执行通用操作。使用类型约束实现特定类型泛型,为指定类型定制操作。 泛型在 Go 中的特…

    2025年3月6日
    200
  • 如何使用泛型解决golang中并发编程问题

    使用泛型解决 golang 中的并发问题。泛型允许在不指定类型的情况下定义函数和结构,从而创建线程安全的数据结构。例如:定义一个泛型队列 queue[t],其中 t 表示元素类型。使用 sync.mutex 保护队列的并发访问。使用 pus…

    2025年3月6日
    200

发表回复

登录后才能评论