VB.Net程序设计:IComparer的应用,按两个不同类的某个属性比较排序

@H_502_0@比较方法:两个不同的类,其中有一个属性是相同类型的,如日期,或者字符。

@H_502_0@自定义IComparer,实现比较方法

@H_404_4@Imports System.Runtime Imports System.Collections Public Class Form1 Private Sub Button1_Click(sender As System.Object,e As System.EventArgs) Handles Button1.Click Dim ArList As New ArrayList With ArList .Add(New Duty(Date.Now,"Now")) .Add(New DutyTemp(Date.Today,"today")) .Add(New Duty(Date.Today.AddHours(1),"today+1h")) .Add(New DutyTemp(Date.Today.AddDays(1),"today-1day")) .Add(New Duty(Date.Today.AddHours(-1),"today-1h")) .Add(New Duty(Date.Today.AddDays(5),"today-5day")) .Add(New DutyTemp(Date.Today.AddDays(-8),"today-8day")) End With ArList.sort(New DutyComparer) For Each obj As Object In ArList Debug.Print(obj.ToString) Next End Sub End Class Public Class DutyComparer Implements IComparer Public Function Compare(x As Object,y As Object) As Integer Implements System.Collections.IComparer.Compare Dim dtm1,dtm2 As Date Select Case x.GetType Case GetType(Duty) dtm1 = CType(x,Duty).DateFrom Case GetType(DutyTemp) dtm1 = CType(x,DutyTemp).TimeFrom End Select Select Case y.GetType Case GetType(Duty) dtm2 = CType(y,Duty).DateFrom Case GetType(DutyTemp) dtm2 = CType(y,DutyTemp).TimeFrom End Select Return Date.Compare(dtm1,dtm2) End Function End Class '--如果兩個不同類可以抽象處理,實現相同接口,就比較容易點。 Public Class Duty Property DateFrom As Date Property DutyName As String Sub New(dtmFrom As Date,strName As String) DateFrom = dtmFrom DutyName = strName End Sub Public Overrides Function ToString() As String Return String.Format("{0}-{1}",DateFrom.ToString,DutyName) End Function End Class Public Class DutyTemp Property TimeFrom As Date Property DutyTempName As String Sub New(dtmFrom As Date,strName As String) TimeFrom = dtmFrom DutyTempName = strName End Sub Public Overrides Function ToString() As String Return String.Format("{0}-{1}",TimeFrom.ToString,DutyTempName) End Function End Class @H_502_0@

@H_502_0@对比结果:

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...