[转载]技巧:谈谈J2ME解决手机Game的内存问题

技巧:谈谈J2ME解决手机Game的内存问题
你可能想,为什么要谈内存,我们可爱的Java不是有gc机制吗?可惜我们现在不是在pc上,而是只有64k内存的手机。如果不多加小心谨慎的话,我们的gc很可能每十秒钟运行一次呢。你会不会毫不犹豫地写下这样的代码:




1. 
g.drawString
(“score=”+score,50,50,
Graphics.TOP|Graphics。LEFT)
?
  或是
2.
for 
(Enumeration e = v.elements() ;
e.hasMoreElements() ;
)
{
System.out.println(e.nextElement());
  }
  

有什么问题?其实它做了下面的事:

String scoreStr=“score=”+score;
g.drawString
(scoreStr,50,50,Graphics.TOP|Graphics.LEFT);


明白了吗?在你的J2ME游戏里,这行程序很可能在paint()里面出现并且每0.1秒运行一次吧。伴随着时间的推移,成堆的String被创建出来,要不了多久,我们可爱的gc妈妈就要出来喽。想到了就简单了,根据我们midlet的实际情况,让我们灵活地建立解决de方法。

差不多也发生了同样的事情,注意到interface Enumeration只有两个method:

boolean hasMoreElement();
Object nextElement();


发现了什么?Enumeration不像STL的iterator,没法让一个原有的Enumeration从头开始,每遍历一次我们的Vector或Hashtable,我们就得问我们的容器要一个新的Enumeration。

常见的情况是:

碰撞检测。我们不得不在每一个frame里对容器做遍历,其结果就是生出以集装箱为单位的大把Enumeration,使用Enumeration很酷,不过为了内存,我们还是老土一点:

for (int loop ; 
loop  
System.out.println
(vector.elementAt(loop));
}


最后,只要善用wtk的Monitor,就能及时地发现我们MIDlet中的内存杀手,将lag消饵于无形之中。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-131739/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-131739/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值