科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道应用软件优化你的PowerBuilder程序

优化你的PowerBuilder程序

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文介绍如何优化PowerBuilder程序,提高执行效率,提高代码的可重复利用性,提高程序的可读性

作者:51cto.com整理 来源:51cto.com  2007年9月15日

关键字: 软件

  • 评论
  • 分享微博
  • 分享邮件

5. 数据窗口属性的访问和修改

A. 数据窗口属性的访问

在程序中访问数据窗口的属性有下列几种方法:

A1. 采用点表达式访问

A2. 应用多个独立的 DESCRIBE() 函数访问

A3. 只使用一个 DESCRIBE() 函数, 采用复合参数访问多个属性

上面三中方法, 通常第一种方法最慢, 第三种方法最快.  

例如:  

在窗口的 OPEN 事件中

DW_1.SETTRANSOBJECT(SQLCA)

DW_1.RETRIEVE()

第一种方法:  

在检索按钮的 CLICKED 事件中编程.

string dx, dy, dh, dw

dx = dw_1.object.da_dh.x

dy = dw_1.object.da_dh.y

dx = dw_1.object.da_dh.height

dy = dw_1.object.da_dh.width

st_1.text =dx+","+dy+","+dh+","+dw

第二种方法:

string dx, dy, dh, dw

dx=dw_1.describe("da_dh.x")

dx=dw_1.describe("da_dh.y")

dx=dw_1.describe("da_dh.height")

dx=dw_1.describe("da_dh.width")

st_1.text =dx+","+dy+","+dh+","+dw

第三种方法:

string dx, dy, dh, dw

st_1.text=dw_1.describe("da_dh.x" +&

"da_dh.y" +&

"da_dh.height" +&

"da_dh.width")

实验证明, 第三种方法的速度是最快的. 但是程序的可读性最差.

B. 数据窗口属性的修改

在程序中修改数据窗口的属性有下列几种方法:

A1. 采用点表达式修改

A2. 应用多个独立的 MODIFY() 函数访问

A3. 只使用一个 MODIFY() 函数, 采用复合参数访问多个属性

上面三中方法, 通常第一种方法最慢, 第三种方法最快.  

例如:  

在窗口的 OPEN 事件中

DW_1.SETTRANSOBJECT(SQLCA)

DW_1.RETRIEVE()

第一种方法:  在检索按钮的 CLICKED 事件中编程.

DW_1.SETREDRAW(FALSE)

dw_1.object.da_dh.x = 18

dw_1.object.da_dh.y = 16

dw_1.object.da_dh.height = 100

dw_1.object.da_dh.width = 200

DW_1.setredraw(true)

st_1.text =dx+","+dy+","+dh+","+dw

第二种方法:

DW_1.SETREDRAW(FALSE)

dw_1.modify("da_dh.x = 18")

dw_1.modify("da_dh.y = 16")

dw_1.modify("da_dh.height = 100")

dw_1.modify("da_dh.width = 200")

dw_1.setredraw(true)

第三种方法:

dw_1.modify("da_dh.x=18" +&

"da_dh.y=16" +&

"da_dh.height=100" +&

"da_dh.width=200")

实验证明, 第三种方法的速度是最快的. 但是程序的可读性最差.注意, 在方法一和方法二中, 都使用的 setredraw() 函数以减少屏幕的重绘, 否则, 执行速度将严重下降.

6. 数据窗口中数据的访问  

在程序中, 经常会需要动态的修改数据窗口中的数据. 对此, PB 提供了多种方法, 各种方法在性能上会有一些差异.

A. 数据窗口中数据的访问

目的: 将数据窗口中的电话号码存放在一个数组中.请比较下面两中方法.

方法一:

string da_dh[]

long ll,i  

ll = dw_1.rowcount()

for i = ll to 1 stet -1

da_dh[i] = dw_1.getitemstring(i,"dhhm")

next

方法二:  

string da_dh[]

da_dh[] = dw_1.object.dhhm.current

测试发现, 第二种方法比第一种方法快将近一倍. 数据量越大这种差异越明显.

B. 数据窗口中数据的修改

目的: 修改数据窗口中的电话号码列的值.

请比较下面两中方法.

方法一:

dw_1.setitem(i,"dhhm",l_name)

方法二:  

dw_1.object.name[i] = l_name

测试发现, 第二种方法比第一种方法快将近一倍. 数据量越大这种差异越明显.

7. 数据窗口事件对性能的影响

对于数据窗口控制中经常发生的事件, 应当尽量减少其中的程序代码.

特别是如下事件:

A. itemchanged

b. editchanged

c. itemfocuschanged

d. pbm_dwnkey

e. rowfocuschanged

f. retrieverow

在这些事件中的任何处理程序, 都会降低应用程序的处理速度. 所以应当尽量减少这些事件中的处理程序, 必要时, 可以考虑只将重要的代码放在这些事件中, 而将剩余的代码放在一个传递的事件中.

例如,如果需要用到数据窗口的 ROWFOCUSCHANGED 事件,可以为数据窗口定义一用户事件 "UE_RE",而在数据窗口的 ROWFOCUSCHANGED 事件中写如下代码:

PARENT.postevent("ue_re") 

在 UE_RE 事件中再编写相应的程序代码,如:

string code  

dw_1.selectrow(0,false)

dw_1.selectrow(rownum,true)

code = getitemstring(dw_1,rownum,"dhhm")

dw_2.retrieve(code)

另外, 为了获得当前行号,应尽量使用数据窗口的 CURRENTROW 变量,而少用 GETROW() 函数。

8、 数据窗口的列名称与列编号

对数据窗口的某列进行访问, 可以采用该列的名称, 也可以使用该列的编号,例如:

采用列编号:

dw_1.object.data[ll_row,2]

dw_1.getitemstring(3,2)

采用列名称表示某列:

dw_1.object.article_text[ll_row]

dw_1.getitemstring(3,"dhhm")

dw_1.setitem(3,"date",1999-03-31)

...

对于以上两种方法, 如果只进行一次查询, 在速度上并没有太大的区别,如过需要循环访问数据窗口上的某一列, 则速度上的差异就表现的比较明显,才用第一种方法要快, 但是程序的可读性比较差。但是, 在使用函数时(如 GETITEM() 和 setitem() ), 执行速度往往没有很大差别。

9、 计算域

数据窗口的计算域会对数据的操作性能产生影响。 如果数据窗口中包含许多复杂的计算域,将严重影响数据窗口的执行速度。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章