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. mac 安装oracle

    http://www.oracle.com/technetwork/cn/database/10204macsoft-x86-64-087400-zhs.html

  2. unable to execute dex:GC overhead limit exceeded unable to execute dex:java heap space 解决方案

    最近做厂商适配,厂商提供了一部分Framework的jar包,把jar包通过Add Jar放到Build Path中, 在生成APK过程中,Eclipse长时间停留在100%那个进度. 最后Eclip ...

  3. 用Broadcast Receiver刷新数据(二)

    采用消息发布/订阅的一个很大的优点就是代码的简洁性,并且能够有效地降低消息发布者和订阅者之间的耦合度.举个例子,比如有两个界面,ActivityA和ActivityB,从ActivityA界面跳转到A ...

  4. system times on machines may be out of sync

    今天在hadoop集群执行任务的时候报了一个这个错误,听名字应该是三台机器的时间不同步.于是同步一下时间即可解决 1.安装ntpdate工具 yum -y install ntp ntpdate 2. ...

  5. mysql的介绍和安装

    本节内容 1.数据库介绍 2.mysql管理 3.mysql数据类型 4.常用mysql命令 创建数据库 外键 增删改查表 5.事务 6.索引 1.数据库介绍 什么是数据库? 数据库(Database ...

  6. 从CES看2016物联网发展趋势

    [导读] 美国时间1月6号,千呼万唤始出来的2016年国际消费电子展(CES2016)在拉斯维加斯正式拉开序幕.三天会展完满落幕,这个被誉为全球消费电子技术风向标的北美最大消费电子展俨然变成了未来智慧 ...

  7. Android 让GridView的高度为Wrap_content根据内容自适应高度

    From:http://www.jayway.com/2012/10/04/how-to-make-the-height-of-a-gridview-wrap-its-content/ 如果把Grid ...

  8. Morris InOrder Traverse Binary Tree 无需使用递归和栈

    今天在切leetcode的时候看到一个Morris算法,用来中序遍历二叉树,非递归,O(1)空间.觉得很强大.记录一下. 基本思想是利用了Threaded Binary Tree. 步骤如下: cur ...

  9. 03Del.ashx(删除班级)

    03Del.ashx 数据库里定义个BOOL型,TRUE表示正常FALSE表示删除 using System; using System.Collections.Generic; using Syst ...

  10. 玩转JavaScript Callback函数

    如果你对Jquery没有足够的经验,但是你又用过JQuery,这么来说没你已经用过了回调函数了.但是你可能不知道它是如何工作和实现的. 这篇文章主要基于我所了解的回调函数,我试图启发大家基于最常规的J ...