机房重构--哈希表

  看到哈希表相信大家都很熟悉了,但是如何的使用哈希表!只是学过理论知识的你用起来就有点吃力了吧!今天就在机房中解说哈希表。
  在机房组合查询中我们需要用到中英文转换,这是哈希表就用到了。

  组合查询中的模板UI层

'实例化组合查询的实体
  Protected GroupInquiryInfo As New Entity.LineStateEntity
  Private Sub btnCheck_Click(sender As Object, e As EventArgs) Handles btnCheck.Click               
        GroupInquiryInfo.ComboName1 = ChangeEnglish(ComboName1.Text'调用哈希表
        GroupInquiryInfo.ComboName2 = ChangeEnglish(ComboName2.TextEnd Sub

  继承窗体UI层代码

 Private Sub frmSeekLineState_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        '字段内容添加  用户字段
        Dim FieldName() As String    '定义存储对象
        FieldName = {"卡号", "上机时间", "下机时间", "消费时间", "消费金额"}
        ComboName1.Items.AddRange(FieldName)  '把FieldName中的信息显示在ComboName1中以供选择    
    End Sub

  哈希表

'将汉字转换为相应的字段名
 Public Overrides Function ChangeEnglish(control As String) As String   '如果重写方法需要Overrides   可用重写时用
        Dim FieldName() As String     '定义存储对象
        Dim GetDBName() As String      '定义存储对象
        FieldName = {"卡号", "上机时间", "下机时间", "消费时间", "消费金额"}
        GetDBName = {"UserID", "Logindate", "Logoutdate", "ConsumeTime", "ConsumeCash"}
        Dim ht As Hashtable = New Hashtable()
        For i = 0 To FieldName.Count - 1       '给哈希表赋值 键值都是字符类型  不能是集合
            ht.Add(FieldName(i), GetDBName(i)) 'ht是哈希表
        Next i
        ChangeEnglish = ht.Item(control)
    End Function

  这样就可以使用哈希表了。和我们以前使用的代码有相似的地方来个对比解释一下。

  下面代码和上面的继承UI层下面的代码起到的作用是一样的。

Private Sub frmSeekLineState_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        '字段内容添加  用户字段
        ComboName1.AddItem "卡号"
        ComboName1.AddItem "上机时间"
        ComboName1.AddItem "下机时间"
        ComboName1.AddItem "消费时间"
        ComboName1.AddItem  "消费金额" 
    End Sub

  组合查询中的模板UI层

'实例化组合查询的实体
  Protected GroupInquiryInfo As New Entity.LineStateEntity
  Private Sub btnCheck_Click(sender As Object, e As EventArgs) Handles btnCheck.Click               
        GroupInquiryInfo.ComboName1 = FiledName(ComboName1.Text'调用哈希表
        GroupInquiryInfo.ComboName2 = FiledName(ComboName2.TextEnd Sub

  和哈希表作用相同的代码

Public Function FiledName(StrFiledName As String) As String                    '将汉字转换为相应的字段名
      Select Case StrFiledName
        Case "卡号"
              FiledName = "cardno"
        Case "姓名"
              FiledName = "studentName"
        Case "上机日期"
              FiledName = "ondate"
        Case "上机时间"
              FiledName = "ontime"
        Case "下机日期"
              FiledName = "offdate"
        Case "下机时间"
              FiledName = "offtime"
        Case "消费金额"
              FiledName = "consume"
        Case "余额"
             FiledName = "cash"
        Case "状态"
             FiledName = "status"
        Case "与"
              FiledName = "and "
        Case "或"
              FiledName = "or "
      End Select
End Function

  两种不同的实现方式,你是选用哈希表,还是用容易理解的第二种方式,各有优缺点。看不懂请留言,作者会积极更新。

评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值