.net 中array.sort可以很方便地对一维数组进行排序。但是对复杂的数据结构需要有一些变通的方法。
前提是,该数据结构中具有可以用来排序的KEY值。
举例:我们有一个结构包含两个元素
Private Structure TimeCurveItem
Dim Hour As Integer
Dim T As Single
End Structure
需要对结构数组进行排序,按照Hour从小到大
简单的方法,建立一个数组,复制hour
private sub SortbyHour
Dim Nums(3) As TimeCurveItem
Dim Indexes(3) As Integer
Dim i As Integer
'初始化结构数组
Nums(0).Hour = TextBox1.Text
Nums(1).Hour = TextBox2.Text
Nums(2).Hour = TextBox3.Text
Nums(3).Hour = TextBox4.Text
'复制结构数组的排序项到一个新的一维整型数组
For i = 0 To 3
Indexes(i) = Nums(i).Hour
Next
'排序
Array.Sort(Indexes, Nums)
'输出结果
TextBox5.Text = Nums(0).Hour
TextBox6.Text = Nums(1).Hour
TextBox7.Text = Nums(2).Hour
TextBox8.Text = Nums(3).Hour
end sub
这样的解决方法编程量很小,而且可以适用于结构数组,类数组等多种情况.