Select Case & Try 语句无限循环

Select Case & Try statement infinite loop

当尝试在我的 vb.net 项目中打印报告时,我有一些代码来检查是否所有必填字段都已填写。如果没有,将出现一个消息框通知用户。当他们按下 'OK' 时,我需要程序停止执行加载报告的代码。目前,它陷入了一个无限循环,它会重复执行 Try 函数和 SELECT CASE 函数。

需要改变什么来阻止这种情况?我无法弄清楚问题是什么,以及为什么以下代码部分会一个接一个地循环

Try
    Select Case checkwhat.ToUpper
        Case "SUPPLIER"
            If cmbSuppliers.Text.Trim = "" Then
                MsgBox("Please select a supplier", MsgBoxStyle.OkOnly, "No Supplier Selected")
                Return False
                Exit Try
            End If
        Case "RB6B"
            check("SUPPLIER")
            If check("SUPPLIER") = True Then  Else Exit Sub
            createWorkTable("SUPPLIERS-TERRITORY-LS")
            regReport("rTerritoryWTableCrosstabB.rpt", "", con, Me.MdiParent, cReport, True)
            fillPms(cReport, "Sales by Territory by Supplier", "For " & cmbSuppliers.Text.Trim, "", "AOT02")

这不是一个完整的答案,但我至少可以解决一些问题:

Select Case checkwhat.ToUpper
    Case "SUPPLIER"
        If cmbSuppliers.Text.Trim = "" Then
            MsgBox("Please select a supplier", MsgBoxStyle.OkOnly, "No Supplier Selected")
            Return False
            Exit Try '<- Redundant
        Else
            ' Perform other checks
            Return True
        End If

所以这意味着假设您输入供应商案例,您至少可以获得两个 return 值。

现在.. 在你的 RB6B 案例中,你 运行 check 函数两次。

Case "RB6B"    
    check("SUPPLIER")
    If check("SUPPLIER") = True Then

您有两个选择:

Dim supplierValid as Boolean = check("SUPPLIER")
If supplierValid = True

或者只删除第一行

If check("SUPPLIER") = True Then

好的。那么接下来:

If check("SUPPLIER") = True Then Else Exit Sub

尽量避免使用这种风格,因为它可以隐藏代码路径,您可能会在不知不觉中错过一些功能。两个选项如下所示。一是避免额外的嵌套

If check("SUPPLIER") = True Then  
    createWorkTable("SUPPLIERS-TERRITORY-LS")
    regReport("rTerritoryWTableCrosstabB.rpt", "", con, Me.MdiParent, cReport, True)
    fillPms(cReport, "Sales by Territory by Supplier", "For " & cmbSuppliers.Text.Trim, "", "AOT02")
Else 
    Exit Sub
End If

If check("SUPPLIER") = False Then
    Exit Sub
End If  

createWorkTable("SUPPLIERS-TERRITORY-LS")
regReport("rTerritoryWTableCrosstabB.rpt", "", con, Me.MdiParent, cReport, True)
fillPms(cReport, "Sales by Territory by Supplier", "For " & cmbSuppliers.Text.Trim, "", "AOT02")