Java学习:解决J2ME中的内存泄漏

2016-02-19 13:37 3 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐Java学习:解决J2ME中的内存泄漏,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - 编程语言 】

不知道主题为"J2ME中的内存泄漏"是否妥当,不过在J2ME中假如处理不好资源的创建和释放问题,也会出现类似在CC++中的内存泄漏现象。
  
  J2ME中最常使用的资源无非是图片和声音。为了提高游戏的运行速度,我们通常把它们声明为全局变量,又由于手机的内存的关系,我们不能把这些资源同时加载进内存,所以我们会在使用的时候导入资源(创建对象),而把暂时不需要的资源(图片或声音)对象赋值为null(当然这是我的做法,不知道是否和大家一样)。在这期间假如处理不好,就会有些资源对象的在内存中没有清除干净,就会造成内存泄漏,结果就是可用内存越来越小。下面我就举例说明。
  
  1.图片资源
  要点:要为每一个图片资源声明一个对象变量
  假设在一个程序声明了2个图片对象:
  Image pic1,pic2;
  假如在某一时刻要使用pic1和pic2则:
  if(pic1==null)pic1=Image.createImage("/1.png");
  if(pic2==null)pic2=Image.createImage("/2.png");
  当这些图片用完后,就应当:
  pic1=null;
  pic2=null;
  假如需要使用另外两个图片3.png和4.png,则最好另声明两个变量对象pic3,pic4来导入它们,不要使用pic1,pic2变量来导入这两个图片,如:
  if(pic1==null)pic1=Image.createImage("/3.png");//不要这样做
  if(pic2==null)pic2=Image.createImage("/4.png");//不要这样做
  因为这样做会影响垃圾收集器对pic1,pic2对象的回收工作,从而造成内存回收不干净。
  
  2.声音资源(不同的平台对声音的处理方式不同)
  
  要点:和图片资源一样,另外在回收声音资源一定要停止声音的播放;还有在每次开始播放声音前,也要先判定一下声音的状态(简单点,直接调用stop,先让声音停下来,然后再播放),假如不先停止声音的播放,再调用其运行播放,可能会生成无法回收的对象(这是本人猜测的)造成内存的泄漏。
  
  如:
  假设sound为声音对象
  释放sound资源:
   if(sound!=null)
   {
   sound.stop();
   sound=null;
   }
  这样sound的资源就可以安全的被垃圾回收器收回了
  播放声音资源:
   if(sound!=null)
   {
   sound.stop();
   sound.start();
   }
  以上就是我的经验之谈,也许有错误的地方请大家原谅。谢谢

来源:http://www.tulaoshi.com/n/20160219/1604812.html

延伸阅读
随着移动通信的突飞猛进,移动开发这个新鲜的字眼慢慢成为开发者关注的热点。在网上进行的最近一份调查显示,有24.34%的受访者涉足嵌入式/移动设备应用开发,这个数字可能略高于实际的比例,但也足可说明嵌入式/移动设备应用开发是一块诱人的新鲜奶酪。 !-- frame contents -- !-- /frame contents -- J2ME(Java 2 Micro Edition)...
我们将从定义 J2ME 开始,从最简单的J2ME 是什么开始讲起。然后讨论它的总体架构并学习 J2ME 目标设备。作为架构讨论的一部分,我们将提供有关简表和配置的概述。同时我们会简要介绍打包和配置 J2ME 应用程序过程中的一些注重事项。 J2ME 是什么? Sun Microsystems 将 J2ME 定义为“一种以广泛的消费性产品为目标的的高度...
有几个想学J2ME的朋友问过我这个问题。我想这个问题可以有两个答案。 J2ME是简单的。 !-- frame contents -- !-- /frame contents -- 说其简单,更主要的原因是J2ME开发使用的是Java,离开平台技术范畴(J2SE,J2ME,J2EE),Java语言本身是简单的,或者说“简洁”更为强大。比起C++的程序代码来说,Java Code让人看起来更舒适,也更直观。 ...
一、编写易于移植的J2ME代码 !-- frame contents -- !-- /frame contents -- 我写第一个J2ME游戏的时候,根本就没想过移植的问题。所以那个游戏也就很难移植了。反过来,假如你已经计划好要移植了,那么事情就简单的多。这一节说的是代码问题。那就想想,不同手机之间在代码上会有哪些差异。 (1) 屏幕尺寸不同 这儿谈的主要问...
一、编写易于移植的J2ME代码 我写第一个J2ME游戏的时候,根本就没想过移植的问题。所以那个游戏也就很难移植了。反过来,假如你已经计划好要移植了,那么事情就简单的多。这一节说的是代码问题。那就想想,不同手机之间在代码上会有哪些差异。 (1) 屏幕尺寸不同 这儿谈的主要问题,是自适应控件。所谓控件,就是菜...

经验教程

629

收藏

33
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部