在决定使用 List<T> 还是使用 ArrayList 类(两者具有类似的功能)时,记住 List<T> 类在大多数情况下执行得更好并且是类型安全的。 如果对 List<T> 类的类型 T 使用引用类型,则两个类的行为是完全相同的。 但是,如果对类型 T 使用值类型,则需要考虑实现和装箱问题。想二维数组和一维数组那样能用好多方法,在这里可以实现:那就是利用泛型List<T>。

举个例子:

view plaincopy to clipboardprint?
List<List<int>> array1 = new List<List<int>>();  List<int> array2 = new List<int>();         array2.Add(2);  array2.Add(3);  array2.Add(6);  array2.Add(6);  array2.Add(6);  List<int> array3 = new List<int>();  array3.Add(1);  array3.Add(4);  array3.Add(5);  array3.Add(12);  array3.Add(32);  array3.Add(42);  array1.Add(array2);  array1.Add(array3);  List<string> array4 = array1[0];  List<string> array5 = array1[1];

  

------------------------------------------------------------------

原理是:把列表合并再拆开,把数组中的每一行看做是一个列表的数据。

代码中定义两个列表的类型array1,利用List<T>的方法赋值,之后拆开,把值传到两个列表中。这样就实现了二维数组的赋值取值。这是二维数组,多维数组举一反三。例子只是为了说明用法 毫无代码价值。

C#泛型列表List<T>基本用法总结:(饮水思源:http://space.itpub.net/14466241/viewspace-624132)

示例代码如下:

namespace SampleListT
{
  class Program
  {
      static void Main(string[] args)
      {
          //using System.Collections.Generic; 命名空间中的List<T>
          //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<Person> list = new List<Person>(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<int> l2 = new List<int>() { 1 ,2 ,3 ,4 ,5 };

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

//构造传入批量参数 ,与AddRange效果一样
          List<Person> mylist = new List<Person>(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<T>都是提供了索引器来访问的
          Console.WriteLine( "----------------访问元素------------------------");

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

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

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

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

List<Person> lists2 = new List<Person>(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<Person>,在比较方法中,始终返回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<Person> ls3 = new List<Person>(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>(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<Person> 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<T> comparison); //我们的Person并没有实现那个接口,所以要用泛型委托当参数的方法
          //public void Sort(IComparer<T> comparer); //泛型接口当参数 public delegate int Comparison<T>(T x, T y);
          //public void Sort(int index, int count, IComparer<T> comparer); //可以指定范围

List<Person> ls4 = new List<Person>(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<TOutput> ConvertAll<TOutput>(Converter<T, TOutput> converter);
          // public delegate TOutput Converter<TInput, TOutput>(TInput input);  委托参数
          List<Racer> ls5 = ls4.ConvertAll<Racer>((input) => new Racer(input.name)) ;

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

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

ReadOnlyCollection<Racer> 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<Person>
  {
      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;
      }
  }

}

转载于:https://www.cnblogs.com/canlay/archive/2011/09/06/2168507.html

C#泛型列表List实现二维数组的功能(令附C#泛型列表List基本用法总结)相关推荐

  1. php 数组与数组之间去重,PHP开发中一维数组与二维数组去重功能实现教程

    本篇文章讲述了PHP实现一维数组与二维数组去重功能示例.希望对在php学习和开发的同学有所帮助! 数组中重复项的去除 一维数组的重复项: 使用array_unique函数即可,使用实例如下: ? $a ...

  2. php 二维数组中去重,PHP实现二维数组去重功能示例

    PHP实现二维数组去重功能示例 发布于 2017-08-07 21:05:17 | 68 次阅读 | 评论: 0 | 来源: 网友投递 PHP开源脚本语言PHP(外文名: Hypertext Prep ...

  3. 案例演示Python二维列表与Java二维数组

    1.Python二维列表案例演示 运行程序,结果如下: 2.案例演示Java二维数组 package net.hw.test;/*** 功能:二维数组用法示例* 作者:华卫* 日期:2013年12月1 ...

  4. python二维列表添加_Python二维数组

    二维数组是数组中的数组. 它是一个数组的数组. 在这种类型的数组中,数据元素的位置由两个索引,而不是一个索引来引用. 所以它表示了一个包含行和列的数据的表. 在下面的二维数组的例子中,每个数组元素本身 ...

  5. python二维列表添加_Python - 二维数组

    二维数组是数组内的数组.它是一个数组数组.在这种类型的数组中,数据元素的位置由两个索引而不是一个索引来引用.所以它代表了一个包含行和dcolumns数据的表格.在下面的twp维数组的例子中,每个数组元 ...

  6. python 二维数组元素返回二维坐标_python – 从二维数组中返回生成器而不是位置列表...

    我昨天正在进行一场游戏,我必须遍历一个二维阵列并找到标记为"d"的任何单元格的位置(其中单元格表示为" – "表示空白,"d"表示为脏). ...

  7. 炫技:拼接列表、破碎二维数组——Python sum()函数隐藏技能花式玩法

    sum()函数(Python内建)我们都用得不少,但她还有隐藏特技!您可知晓?

  8. 剑指offer_第1题_二维数组中的查找

    题目描述 在一个二维数组中(每个一维数组的长度相同) 每一行都按照从左到右递增的顺序排序 每一列都按照从上到下递增的顺序排序. 请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整 ...

  9. jupyter notebook多维数组运算_Python创建二维数组的正确姿势

    List (列表)是 Python 中最基本的数据结构.在用法上,它有点类似数组,因为每个列表都有一个下标,下标从 0 开始.因此,我们可以使用 list[1] 来获取下标对应的值.如果我们深入下列表 ...

最新文章

  1. c++学习笔记之静态成员函数
  2. Transformer、BERT学习笔记
  3. _LVM——让Linux磁盘空间的弹性管理
  4. scrapy框架爬虫文件配置
  5. 在C#中使用代理的方式触发事件 的简单习作
  6. 13.JAVA基础:八进制,十六进制表示
  7. sqlserver两个日期之间的年数_SQL语句计算两个日期之间有多少个工作日的方法
  8. goroutine调度详解,以及进程、线程、协程区别
  9. 虎扑入股“造物”App关联公司 后者为模玩、手办平台
  10. Repeater控件里面取不到CheckBox的值
  11. 你觉得iPhone吸引你的是什么?
  12. 汇率兑换查询易语言代码
  13. 华易记账宝 v6.5
  14. Ubuntu 18.04 安装 NVIDIA 显卡驱动
  15. Linux关闭/禁用触摸屏,deepin关闭/禁用触摸屏方法
  16. 一文看懂开源许可证丨开源知识科普
  17. leetcode 174:地下城游戏
  18. oc对mysql支持_iOS中数据库使用什么技术实现的
  19. 互联网公司 概率面试题整理
  20. graythresh

热门文章

  1. windows下使用svn命令行
  2. SecurityContextPersistenceFilter和SecurityContextHolder的作用
  3. dederss.php美国与,Dede经验:全站rss/连载和分类首页模板替换
  4. python中的loop啥意思_python怎么进行loop
  5. python生成指定位数随机数_python生成指定长度的随机数密码
  6. Elasticsearch 动态添加mapping
  7. 几款强大的 Pandas 数据探索工具,推荐收藏使用
  8. 已拿30K offer!感谢这几个公众号提供的各种学习教程
  9. 强化学习核心文章一百篇
  10. hadoop3伪分布式安装