2009-01-19 20:10

c# ArrayList 的排序问题!

c# ArrayList 的排序问题!

我看见网上有人用IComparer接口实现ArrayLIst 的排序问题 ,于是自己写了个小例子,编译已经通过,和大家一块分享。有不足之处,望不吝指正。

1、建一个结构雇员结构

private struct Eployee{

public string name;

public int age;

public string sex;

}

2、新建3个"雇员"

Eployee ep1=new Eployee();

ep1.name="小张";

ep1.age=21;

ep1.sex="男";

Eployee ep2=new Eployee();

ep2.name="老李";

ep2.age=43;

ep2.sex="男";

Eployee ep3=new Eployee();

ep3.name="施施";

ep3.age=18;

ep3.sex="男";

3、将3个"雇员" 加入"雇员列表";

ArrayList EmployeeList=new ArrayList();

EmployeeList.Add(ep1);

EmployeeList.Add(ep2);

EmployeeList.Add(ep3);

好了一切准备就绪,现在希望EmployeeList中得"雇员"是按年龄排序

ArrayList 提供了我们现成排序方法Sort();

它有三个重载,不管使用哪一个,至少要你提供一个Comparer:IComparer;来告诉Sort方法 你对"雇员"们排序依据。

这个Comparer必须实现接口:System.Collections.IComparer ,该接口只有一个成员函数需要你去实现。

描述如下:

[C#]

int Compare(

object x,

object y

);

[JScript]

function Compare(

x : Object,

y : Object

) : int;

知道了这些那我们来实现一个吧

private class myEmployeeCompare:System.Collections.IComparer {

public int Compare(object x,object y){

return ((Eployee)x).age-((Eployee)y).age;

}

}

因为我们比较是“雇员”age,所以我们可以放心写实现语句

return ((Eployee)x).age-((Eployee)y).age;

myEmployeeCompare EmployeeCompare=new myEmployeeCompare();

ok现在我们可以对"雇员"们按年龄排序了

EmployeeList.Sort(EmployeeCompare);

源码:

using System; 
       using System.Collections;

class ArrayListT{
       private struct eployee
        {
                public string name;
               public int age;
                 public string sex;
         }
       ArrayListT(){}

class eployeeCompare: System.Collections.IComparer
        {

public int Compare(object x,object y)
               {
                            return ((eployee)x).age - ((eployee)y).age;
                 }

}

public static void Main()
        {
                eployee ep1 = new eployee();
                ep1.name = "小张";
               ep1.age = 21;
               ep1.sex = "女";

eployee ep2 = new eployee();
                ep2.name = "小李";
               ep2.age = 20;
               ep2.sex = "女";

eployee ep3 = new eployee();
                ep3.name = "小王";
                 ep3.age = 26;
               ep3.sex = "女";

ArrayList list = new ArrayList();
                list.Add(ep1);
                list.Add(ep2);
                 list.Add(ep3);

eployeeCompare eployee = new eployeeCompare();
  
                 list.Sort(eployee);

foreach (eployee ep in list)
                {
                       Console.WriteLine("the eployee's name is :{0} age is{1}",ep.name,ep.age);
                 }  
               Console.ReadLine();

}
         }

c# ArrayList 的排序问题!的更多相关文章

  1. ArrayList等常见集合的排序问题

    对于ArrayList等常用的集合具体业务类,基本上都实现了Comparable接口,即可以用来比较装载的对象实体. 主要用Collections.sort方法对集合类中的对象进行排序 Collect ...

  2. 关于spring aop Advisor排序问题

    关于spring aop Advisor排序问题 当我们使用多个Advisor的时候有时候需要排序,这时候可以用注解org.springframework.core.annotation.Order或 ...

  3. @NamedEntityGraphs --JPA按实体类对象参数中的字段排序问题得解决方法

    JPA按实体类对象参数中的字段排序问题得解决方法@Entity @Table(name="complaints") @NamedEntityGraphs({ @NamedEntit ...

  4. java Collection中的排序问题

    java Collection中的排序问题 这里讨论list.set.map的排序,包括按照map的value进行排序. 1)list排序 list排序可以直接采用Collections的sort方法 ...

  5. 编程之美—烙饼排序问题(JAVA)

    一.问题描述 星期五的晚上,一帮同事在希格玛大厦附近的"硬盘酒吧"多喝了几杯.程序员多喝了几杯之后谈什么呢?自然是算法问题.有个同事说:"我以前在餐      馆打工,顾 ...

  6. 计算机程序的思维逻辑 (38) - 剖析ArrayList

    从本节开始,我们探讨Java中的容器类,所谓容器,顾名思义就是容纳其他数据的,计算机课程中有一门课叫数据结构,可以粗略对应于Java中的容器类,我们不会介绍所有数据结构的内容,但会介绍Java中的主要 ...

  7. 分享个 之前写好的 android 文件流缓存类,专门处理 ArrayList、bean。

    转载麻烦声明出处:http://www.cnblogs.com/linguanh/ 目录: 1,前序 2,作用 3,特点 4,代码 1,前序  在开发过程中,client 和 server 数据交流一 ...

  8. 深入理解java中的ArrayList和LinkedList

    杂谈最基本数据结构--"线性表": 表结构是一种最基本的数据结构,最常见的实现是数组,几乎在每个程序每一种开发语言中都提供了数组这个顺序存储的线性表结构实现. 什么是线性表? 由0 ...

  9. 【干货】用大白话聊聊JavaSE — ArrayList 深入剖析和Java基础知识详解(二)

    在上一节中,我们简单阐述了Java的一些基础知识,比如多态,接口的实现等. 然后,演示了ArrayList的几个基本方法. ArrayList是一个集合框架,它的底层其实就是一个数组,这一点,官方文档 ...

随机推荐

  1. AssetBundle 在Android机子上进行读取 .

    http://game.ceeger.com/Manual/StreamingAssets.html 我看到官方文档中说明:Note that bundles are not fully compat ...

  2. m2014-architecture-imgserver->配置lighttpd mod_mem_cache 模块做静态资源服务器

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://freehat.blog.51cto.com/1239536/989171 一 l ...

  3. C++11新特性之五——可变参数模板

    有些时候,我们定义一个函数,可能这个函数需要支持可变长参数,也就是说调用者可以传入任意个数的参数.比如C函数printf(). 我们可以这么调用. printf(); 那么这个函数是怎么实现的呢?其实 ...

  4. 在Win64系统上动态加载无签名驱动:WIN64LUD

    1.WIN64LUD的全称是WIN64 Load Unsigned Driver,功能如其名,在WIN64系统上加载无签名的驱动. 2.支持Windows 7/8/8.1/2008R2/2012/20 ...

  5. android框架---->下沉文字Titanic的使用

    Titanic is a simple illusion obtained by applying an animated translation on the TextView TextPaint ...

  6. 【BZOJ3362-3365】USACO水题四连A

    [BZOJ3362][Usaco2004 Feb]Navigation Nightmare 导航噩梦 Description     农夫约翰有N(2≤N≤40000)个农场,标号1到N,M(2≤M≤ ...

  7. xcode官网下载地址

    https://developer.apple.com/downloads/

  8. Sublime的使用!emmet常用快捷键梳理

    多的不说了! 示例一: !+tab 效果: <!doctype html> <html lang="en"> <head> <meta c ...

  9. PL/SQL编程基础(三):数据类型划分

    数据类型划分 在Oracle之中所提供的数据类型,一共分为四类: 标量类型(SCALAR,或称基本数据类型) 用于保存单个值,例如:字符串.数字.日期.布尔: 标量类型只是作为单一类型的数据存在,有的 ...

  10. Mongo Rocks 在SSD盘上表现优秀,专门为SSD盘的优化

    2017 · MongoDB深圳用户组大会全记录 | MongoDB中文社区http://www.mongoing.com/2017/04/24/mongodb-shenzhen-user-group ...