对外观模式的讨论

  在做完机房收费系统三层的登录时,要求添加设计模式实现,毋庸置疑的是访问数据库肯定是用抽象工厂加反射,那外观模式呢,应不应该添加,下面将讨论。仅机房收费系统的登陆


 在系统登录时要判断用户名是否存在,密码是否正确,还要判断用户类型,一个登录要使用三个方法判断如果直接用三层实现,在界面层还需根据逻辑层返回的结果进行判断,一是麻烦二是耦合大。如例1.1

例1.1

        user.UserId = TbUserid.Text.Trim()
        user.UserPW = TbUserPW.Text
        If testpw.TestID(user) = True Then
            MsgBox("账号不存在,请重新输入")
            Exit Sub
        End If
        If testpw.TestPW(user) = True Then
            MsgBox("登入成功")
        Else
            MsgBox("密码错误,请重新输入")
        End If

  

  改善:可以使用外观模式,将判断用户名,密码,用户类型封装起来。在界面层直接调用一个登录的方法就能实现三个判断,一方面方便使用一方面耦合小。

例1.2

        loginuser.UserId = txtUserid.Text.Trim()
        loginuser.UserPW = txtUserPW.Text.Trim()

        facedloginuser.FLogin(loginuser)
这样在界面只 要一个Flogin就能实现登录的判断。至于提示信息,像密码不正确啦,用户名不存在之类的语句,都会在外观层以msgbox 实现,在之前vb中每个窗体中的提示框只能在当前窗体 中显示,而.net中 在其他层,就能控制给出提示框。




当然在添加外观时候并不是那么顺利,就像简单工厂似的也给用错啦。具体情况:

 问题:外观层用错,不如不加。

先看机房收费系统的包图,如图1

对外观模式的讨论_第1张图片





用错了外观,虽说是外观但是没有起到外观的作用,如例1.3

        If facedloginuser.FacedId(TbUserid.Text.Trim()) = False Then '判断用户名是否为空
            MessageBox.Show("账号不能为空,请重新输入")
            TbUserid.Focus()
            Exit Sub
        End If
        If facedloginuser.FacedPW(TbUserPW.Text.Trim()) = False Then '判断密码是否为空
            MessageBox.Show("密码不能为空,请重新输入")
            TbUserPW.Focus()
            Exit Sub
        End If
        If facedloginuser.FacedMethodUser(loginuser) = True Then
            MessageBox.Show("登陆成功")
        End If


当初的外观也是用了三个方法,之所以没有用一个,是在考虑怎么提示用户名存在不存在,想来想去都没有想出来,就用了三个方法,分别提示,但是这样子跟没有加“外观”时的三层不是一个样子


解决问题后:


从包图中可以看到整个系统的结果,系统都分好层后,每个功能的实现,都会用到各个包中的类。所以每个功能的类图是和包图一致的。机房收费系统登录类图,如图2

对外观模式的讨论_第2张图片



这样就可以啦。

附:时序图

对外观模式的讨论_第3张图片


 

你可能感兴趣的:(对外观模式的讨论)