PB代码优化

PB 代码优化

现今计算机的运行速度已经很快了,并且由于老板时常在耳边念着紧箍咒,因此,我们有意或者无意的忘记优化我们的代码,只要能完成任务就行了(我也是)。不过,我们闲下来的时候,不妨也来看看我们的代码是否有需要改进的地方。下面就是我觉得值得优化的几种情况。

第一种情况:

IF condition1 AND condition2 THEN

//Code goes here.

END IF

IF condition1 THEN

IF condition2 THEN

//Code goes here.

END IF

END IF

对于书写的第一种方式,由于 PB 编译方式与常见的方式不同,就是无论条件 1 的值如何,都要对条件 2 进行运算。这样一来,当条件 1 为 false 时,就可能要无谓的对条件 2 进行运算了。就按随机的概率而言,可能会多进行一半的运算。因此,对于大多数情况而言,我想最好是以第二种方式书写。当然,特殊情况也是有的,那就是你的确想对条件 2 进行运算。类似地,对于 or 也一样。

IF condition1 OR condition2 THEN

//Code goes here.

END IF

IF condition1 THEN

//Code goes here.

ELSE

IF condition2 THEN

//Code goes here.

END IF

END IF

第二种情况:

IF NOT condition THEN

//Code goes here.

END IF

IF condition THEN

//No code goes here.

ELSE

//Code goes here.

END IF

对于上一种方式,条件表达式返回 false 并且再进行一个 非 运算,才执行下面的代码。这样相对于下面一种书写方式可能多执行了一个 非 运算。如果大家有什么疑问,您不妨测试一下下面这个例子:

// 小测试:其中的判断条件只是为了表示一下,实际情况可能更复杂。

long i // 计数器

long ll_start // 执行开始时间

long ll_used1 // 方式一耗时

long ll_used2 // 方式二耗时

// 方式一

ll_start = Cpu()

for i = 1 to 900000

if not (1 > 1) Then

i = i

end if

next

ll_used1 = Cpu() - ll_start

// 方式二

ll_start = Cpu()

for i = 1 to 900000

if 1 > 1 Then

else

i = i

end if

Next

ll_used2 = Cpu() - ll_start

// 查看结果

If ll_used2 > ll_used1 Then

MessageBox( " 提示 " , " 前者运行时间短! " )

Else

MessageBox( " 提示 " , " 后者运行时间短! " )

End If

可能有人会说,用下面的那种方式,如果在条件表达式返回 false 的时候,那么, if 下就没有代码,这样看起来就不太舒服。的确是这样。因此,我们在写成上面的那种方式时,尽量保持不要使用 not 运算,而保持条件表达式本身就返回希望的 true 值。

第三种情况:

IF condition1 THEN

//condition1

ELSEIF condition2 THEN

//condition2

ELSEIF condition3 THEN

//condition3

ELSE

//Other

END IF

choose case /expression/

case /item/

/statementblock/

case /item/

/statementblock/

case else

/statementblock/

end choose

对于形如这样的表达式,我想我们一般都没去考虑先后顺序。但是,其实我们应该把最可能发生的情况,放在前面,这样可以避免在对一大堆条件进行判断后,才到我们真正需要运行代码的地方。

第四种情况:

FOR ... TO ...

IF condition THEN

//true

ELSE

//false

END IF

NEXT

IF condition THEN

//true

FOR ... TO ...

//Code goes here

NEXT

ELSE

//false

FOR ... TO ...

//Code goes here

NEXT

END IF

尽管下面这种书写方式,看起来好象代码多了一些,但是却极大的避免了在每个循环中都进行条件判断。其实,一个原则就是,我们应当尽量避免在循环中进行条件判断,而是把条件判断放到循环体的外面进行。

其实,真正对于 PB 语言有特殊性的,也就是第一种情况,对于后面三种情况,对于别的编程语言,我想也同样适用。

这是我的一点体会,谬误的地方请大家指正。

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus