VB.Net中的三元运算符

爱⌒轻易说出口 提交于 2020-12-11 06:52:55
IIf(expr, truepart, falsepart)
参数描述 :
  expr 必要参数。用来判断真伪的表达式。
  truepart 必要参数。如果 expr 为 True,则返回这部分的值或表达式。
  falsepart 必要参数。如果 expr 为 False,则返回这部分的值或表达式。
Note:使用IIF时,不管expr是真还是假,后面的truePart和falsepart都会进行计算,虽然它只返回其中的一个。
   例如,如果 falsepart 产生一个被零除错误,那么程序就会发生错误,即使 expr 为 True。
      原来它对每个表达式都会进行计算,如果某一项为DBnull则就会抛出异常,所以在进行非空判断时应该用if的形式,而不应该用iif
比如下面两行代码,有可能就会抛异常
Me.TextBoxOLevelYear12.Text = IIf(myExamResultsDT.Item(11) Is Nothing, String.Empty, myExamResultsDT.Item(11).O_YEAR)
Me.TextBoxOLevelYear3.Text = IIF(NmyExamResultsDT.Rows.Count>0, NmyExamResultsDT.Rows(0)("O_YEAR"),String.Empty)
PS:
IIF只是类似三元运算符,但并非一样,像上面的代码如果在C#用三元运算符?:判断肯定就没问题。
IIF并不是完全没有用,它有它的特色。比如直接返回常量a=iif(LogicPart,1,2),
在这个时候IIF语法就比IF清晰得多,而且效率更高。

顺便提下循环结构的使用:

For index As Integer = 1 To myExamResultsDT.Rows.Count
gradeList.Add(codeTableOLevelGradeDS.TP_CODE.Select("IS_EXPIRED='N' AND CODE='" + myExamResultsDT.Item(index).O_GRADE_CODE + "'", "CODE"))
index += 1
Next

 

For Each myCodeDR In effecDS.TP_CODE.Rows
If myCodeDR.CODE = "G11" Then
Me.DropDownListOLevelSubject1.Items.Add(New ListItem(myCodeDR.CODE + " - " + myCodeDR.CODE_DESC, myCodeDR.CODE))
End If
Next

原文:https://www.cnblogs.com/pfs1314/archive/2011/08/29/2158283.html

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!