不要追求绝对的公平,红尘之中没有公平而言,人活一世,难得糊涂。                                           it is no use doing what you like, you have got to like what you do.

J2ME性能优化之--方法和内存的评测

上一篇 / 下一篇  2007-04-12 10:28:53 / 个人分类:Mercury LoadRunner

本文是对J2ME游戏性能优化的初步探讨,有不足和错误之处还请及时指出。
9X MI%Cm+@(H0本文目的是使我们的游戏能够更快更稳定的运行,J2ME的有限处理能力和存储能力,使得节省设备资源就显得尤为重要。对代码进行优化和提速我个人觉得是一件恐怖的事情,嘿嘿。但当你解决代码的性能瓶颈,使游戏能够流畅运行又是一件很有成就感的事情。
yJ&d+j.zqX"h'_6o0   本文共分两部分:第一部分介绍我们如何使用工具对方法和内存进行评测;第二部分和大家探讨些优化程序的方法。
W9R#T$DFewT"~;W#b0 
)U@ dUl2rV9i0   性能评测所要做的就是,在游戏运行的时候,记录代码每一部分对内存和处理器的使用情况。在评测的过程中,使我们知道什么地方内存使用过大,什么原因导致游戏运行变慢。
d Co3]r9qr6?0   进行评测我们使用的是Sun公司J2MEWirelessToolkit(WTK2.2)。
qpM:r+@q1Tl0J2MEWirelessToolkit提供了若干用于监视应用程序性能的工具。这些工具能够帮助您调试和优化代码。事件探查器列出应用程序中每个方法的使用频率和执行时间。
H^?8A `"e{1Q0内存监视器显示应用程序运行时内存的使用情况。51Testing软件测试网I_/?k$_Rz Ra
网络监视器显示应用程序传送和接收的网络数据。网络监视器支持多种网络协议,包括HTTP、HTTPS、SMS和CBS。
v`i:o3JPQ(MI#P(Z0跟踪将低级信息输出到KToolbar控制台。
4T!s6L5FX/L7j3}t_0提示:监视功能可能会降低应用程序的执行速度。51Testing软件测试网R0jm]%r'VX @
 
Ol*Wy0V0方法性能评测:
3Nx#jT,tc'n0事件探查器跟踪应用程序中的每个方法。对某次特定的应用程序运行,事件探查器都计算出每个方法占用的时间,以及调用每个方法的次数。当应用程序结束运行并关闭仿真器后,将弹出事件探查器,您可以从中浏览所有的方法调用信息。51Testing软件测试网3A*Y? W HC
要打开事件探查器,请从KToolbar菜单中选择“编辑”>“偏好...”。单击“监视”选项卡。(即Preferences)如果您想查看所有系统实现方法的配置处理信息,请选择“显示系统类”。否则,事件探查器将只显示包含对应用程序方法调用的系统方法。51Testing软件测试网 o)t1YG4~3z^
要打开时间探查器也可以这样:%WTK安装路径%--〉binàprefs.exe来启动工具。
t1Zt(c lI(w0启动工具并选择“监视”,再勾选上事件探查器显示应该是这样:J2ME性能优化之--方法和内存的评测(图一)51Testing软件测试网3qa.DJ#`kOS
 
*G'E^w7f2X.yF9i4|0确定后,即可以。下次启动手机模拟器运行游戏结束后就会弹出事件探查器,并显示有关应用程序中所有方法调用的信息。51Testing软件测试网+OI!g!dB]|
提示:只要勾选了事件探查器每次模拟器结束的时候都会弹出,所以记得不用及时取消该功能,因为它影响模拟器的速度,内存监视器尤为明显。不论模拟器是在什么IDE中打开都会弹出方法事件探查器。
4u `G8X"qpP0
M1j:{$Z&O0J2ME性能优化之--方法和内存的评测(图二)点击查看大图
VX-z8`Z s0 
*E`%XWt Fc:P0事件探查器显示两种类型的信息:方法关系,显示在名为“调用图”的层次结构列表中。51Testing软件测试网 K7l3Fz3N"?
事件探查器的右侧显示每个方法及其子代的执行时间和调用次数。
$v(?+]T m0l0注-从仿真器中获得的配置处理值反映不出真实设备上的实际值。
|0`{)yOpYx\p0调用图显示方法调用的层次结构。调用其他方法的方法显示为文件夹。双击某个方法将其打开,并查看该方法所调用的方法。没有调用任何其他方法的方法显示为灰色圆圈。
@7O \dg5y uA3[0您可以搜索某个特定类或方法名。单击“查找...”,并填写名称。搜索从调用图中的当前选择开始执行,直到最后。如果您想搜索完整的调用图,请在单击“查找”按钮之前选中“环绕”。
!n,w| @)V!z0在调用图中单击不同的节点时,事件探查器的右侧就会显示该节点方法的详细信息。51Testing软件测试网7q!z7ItYVT
事件探查器窗口的右侧显示有关方法的详细信息。您可以看到方法名、方法调用次数以及仿真器使用该方法所用的时间。执行时间有四种不同的描述方法:周期表示方法本身所用的处理器时间。
4dwO?:H,z%M0e5H0%周期表示方法本身所用总执行时间的百分比。
VFJ h8k5G)IS0周期(包括子类)表示某方法及其调用的方法所用的时间。51Testing软件测试网@D ` Q}#iu8{
%周期(包括子类)表示某方法及其调用的方法所用的时间占总执行时间的百分比。
h.ok4_p-y0单击任一列,按照该列进行排序。再次单击该列,可以在升序和降序之间切换。
Fj EB1R.Mg0右窗格显示调用图中当前所选节点中包含的方法。如果您想查看每个方法,请在调用图中单击节点。
Z6h~_.Y3}JH0关于保存就不多说了。
)F3[:JuK xz.[8rv0 51Testing软件测试网f.?CY y B:|*r6iq
内存性能评测51Testing软件测试网9I H9r6|,eFSGa5xp
许多MIDP设备上的内存都不够用。J2MEWirelessToolkit中的内存监视器使您可以方便地检查应用程序内存的使用情况。您可以查看应用程序使用的内存总量,以及每个对象的内存使用情况详细列表。
LJ lUq-c?I*}0要打开内存监视器,请从KToolbar菜单中选择“编辑”>“偏好...”,单击“监视”选项卡。选择“启用内存监视器”。51Testing软件测试网 Zs3Q[tC"S:mI
下次运行模拟器时,就会弹出内存监视器窗口,显示一幅随时间变化的应用程序内存使用情况图。由于创建的每个对象都被记录下来,因此内存监视器会使应用程序的启动速度变慢。最好不要同时勾选两种监视器。 
upt&O'q8s5t3v4jtK0J2ME性能优化之--方法和内存的评测(图三)点击查看大图51Testing软件测试网C| I0XFV%J$Y
 J2ME性能优化之--方法和内存的评测(图四)点击查看大图
@3V:dU Y _d$NdV0 
LrB!M_m4^ Z R x?-p)`0您将看到包含以下列的一个表:名字。对象类名称。
U4f9@]-Q xa5P1z0存活。实例数目。有些可以进行资源回收。
ln7B8v:M)I0总共。应用程序开始运行以来所分配的对象总数。51Testing软件测试网 xdx-\*^*m
总计。对象使用的内存总量。51Testing软件测试网T SQ@#[+g+c~"fM
平均。对象的平均大小,由总计大小除以活动实例数目得到。
)e q,p+L6m)QF0单击任一列标题,按照该列进行排序。
fvu9zxWg0通过从内存监视器窗口菜单中选择“查看”>“查找...”,可以搜索某个特定的类名。特别注意内存使用超出当前分配的堆(图像中红色虚线表示)的情况。51Testing软件测试网[%|:J4j h:E|5c
关于方法和内存的评测就到这里,希望大家在使用中的经验和心得能够共同交流。WTK中还有其他好用的功能哦。下一部分讨论下j2me的调试方法和优化方法。51Testing软件测试网jbV,UR{J@A

TAG:

子木清风 引用 删除 Spark.lee   /   2007-04-13 14:32:50
不太清楚这个东西我也是刚刚接触 还没有搞明白的那
我现在都不知道改如何搞了 郁闷中!!!!
老婆婆 引用 删除 annayin   /   2007-04-13 10:44:35
事件探查器是啥东东?只有java才有吗?
 

评分:0

我来说两句

Open Toolbar