今天是 2026-6-8 星期一 QQ:545684816 TEL:13979373522
首  页 | 汉字编码 | 科普知识 | 竞赛之窗 | 音乐美术 | 婺中电教  
VB代码一行优化
发表时间:2009-10-3    浏览次数:335


   编程要讲效率,尽管现在的计算机,速度是不成问题,但是,如果一行代码能完成,为什么要用更多的代码呢?

1、下列代码,则是对逻辑运算不清楚造成。
  If A=true Then C= Not B  Else  C= B   
  If C=true then D=28 Else D=29
  可以:D=Iif((A XOR B),28,29)

2、布尔赋值,常被人忽略:
  If A= 13 then B=True Else B=False

  可以:B=A=13
  或者:B=(A=13)

3、字串有效性检测:
  If IsNull(StrOrg) Or StrOrg="" then
  可以:If Len(StrOrg & "")<>0 then

4、字串重复次数
  RepeatCount=Ubound(Split(StrOrg,StrFind))
  同样,如果要对字串有效性判断:
  RepeatCount=Iif((Len(StrOrg & "")=0), 0, Ubound(Split(StrOrg,StrFind))

5、有时需要判断字串数组中是否有这一元素,这时最好不用数组,而用分隔符字串
  于是: If Len(OrgStr)= Len(Replace(OrgStr,FindStr)) then
  则表明,此元素不存在。

6、对数组初始化:
  最好用变体,这样,也是一行语句:
  如:IntArr=Array(12,28,29,30,31,52,24,60) 注意,此时需要用变量后缀。
  上面代码,如要定义为长整型,则  IntArr=Array(12&,28&,29&,30&,31&,52&,24&,60&)  要将IntArr 定义为变体

7、判断大小:
  IntMax = Iif((IntA > IntB), IntA, IntB)
  IntMin = Iif((IntA < IntB), IntA, IntB)

8、按索引的Select Case
  Function GetChoice(Ind As Integer)
   GetChoice = Choose(Ind, "Speedy", "United", "Federal")
  End Function

9、按表达式的Select Case(这种转换要求不能有Case Else的才可以这样,否则会出错)
  Function MatchUp (CityName As String)
   Matchup = Switch(CityName = "London", "English", CityName _
   = "Rome", "Italian", CityName = "Paris", "French")
  End Function

10、使用Iif,前面已有。
  Function CheckIt (TestMe As Integer)
   CheckIt = IIf(TestMe > 1000, "Large", "Small")
  End Function

13、字串动态数组是否已初始化
   If Len(Join(StrArr))=0 then  '字串动态数组未初始化

12、指定只读CombBox的当前值,如果能确认这个值就在其中,一定不会错,则:
   Combbox=CurValue
   注意,不可以写成:Combbox.text=CurValue
   前者实际是写 _default 这个属性,而后者则是写Text 因为只读,则会导致错误

13、如果有下列代码:
  Select Case CombBox.text
    Case "London": Call FuncStrLang(3)
    Case "Rome"  : Call FuncStrLang(5)
    ......
  End Select

  则可以用ItemData属性
  即:"London" 的 Itemdata=3, "Rome" 的 Itemdata=5
  于是:Call FuncStrLang(CombBox.ItenData)

14、如果有下列代码:
  Select Case CombBox.text
    Case "London": Call ClsCity.CityIntr_London
    Case "Rome"  : Call ClsCity.CityIntr_Rome
    ......
  End Select

  只要:
  CallByName ClsCity, "CityIntr_" & CombBox.text, vbMethod

15、复制数组到另一变量中:
   Dim iOrgArr(30) as Integer
   Dim iDesArr as Variant
   ......
   iDesArr = iOrgArr
  
   即主变体直接取数组指针,则所有元素都复制了过去

16、如果有下列代码:
   Do While Not RsAdo.Eof
     If len(DesStr)<>0 then DesStr=DesStr & VbTab
     DesStr=RsAdo!Rec_id
     RsAdo.MoveNext
   loop

   则只要:DesStr=RsAdo.GetString()

Copyright© 2006-2026, All rights reserved。
地址:紫阳镇天佑西路8号 站长:汪有万 建站时间:2006-9-1