社区
J2ME
帖子详情
如何注意编码,可减少j2me程序容量?
飘飘白云
领域专家: 操作系统技术领域
2005-09-13 12:18:56
比如:
if( x )
{
a = 0;
}
else
{
a = 1;
}
可省为:
a = 1;
if ( x )
{
a = 0;
}
...全文
244
6
打赏
收藏
如何注意编码,可减少j2me程序容量?
比如: if( x ) { a = 0; } else { a = 1; } 可省为: a = 1; if ( x ) { a = 0; }
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
jsjjms
2005-09-13
打赏
举报
回复
一.代码优化
内存会溢出肯定和代码逃不了关系,99.99%学java的人都知道垃圾回收器是java的一大优点并据此来嘲笑C++。显然这个特性为代码编写者省了不少事,但这个特性却带来了不少隐患。举个例子在游戏当中经常有不同场景的切换,如从游戏逻辑退到主菜单逻辑,对游戏逻辑对象的态度很多人会选择忘记等待垃圾回收器来收尸。乍看之下似乎并无不妥垃圾回收器会来善后。实际上垃圾回收器并非实时的,它不像C++的Delete语句马上释放不用的内存。当从游戏逻辑切换到主菜单逻辑这时两个对象同时存在很可能这时内存就不够用了。读到这里很多人会发现实际上垃圾回收器在j2me上并不怎么好用,从一个角度上来讲在j2me上所有垃圾必须由手工释放,除简单类型以外所有对象都必须显式地置空例如 imgs=null; 实际上java提供了一个不错的工具用来查找内存溢出,java.lang.Runtime.freeMemory() 。它可以返回当前的剩余内存数,将它适当的安放在代码中可以有效的监测内存使用状况。很大一部份的j2me程序员之前都是从事pc软件开发工作,充裕的内存掩盖了许多写代码的不良习惯。如下所示:
//a 不为空
a=new Logic();
很多人可能对此有异议,他们会认为新的对象会把旧的对象冲掉并且释放内存。这里面包含两个问题:1. 该段代码是先创建对象然后再进行赋值操作的,也就是说在这期间有两个对象同时存在这就很可能会产生溢出。2. 这样做也会妨碍垃圾回收器的工作
较好的写法如下:
a=null;
a=new Logic();
虽然麻烦了点但在j2me中还是必要的。接着看下例。
drawString("游戏时间:" + time ,50,50,Graphics.LEFT|Graphics.TOP);
"游戏时间:" + time 很完美在paint()方法当中每次都被刷一遍显示在屏幕上。危机往往隐藏在美丽的外表,该语句会引起新的内存重新分配来存储 "游戏时间:" + time 而显示完以后又必须由垃圾回收器释放,用了双倍时间,并且容易发生内存溢出。依此类推在重复执行的方法里应尽量避免重复定义对象。与paint()方法类似在循环里也有类似的情况存在。
把所有对象的初始化放在构造函数里想必是再正当不过了,大多数人通常的做法是把当前逻辑所要用到的资源通通初始化完毕。
很大一部份的内存溢出都是发生在构造函数中。内存使用的高峰期都是在构造函数中所以避开这个高峰能有效的防止溢出。建议最好的办法是第一次使用时初始化。如下所示
if (img==null){
//初始化
}
现在做游戏很多时候都需要地图数组,声音数组,还有一些其它资源这些资源很多可以放在代码中也有的可以放在文件当中。
强烈建议将这些资源放在文件中需要时在load进来。这些资源文件如果放在代码中则会占用不小的代码段空间,而代码一般是程序一运行就装载到内存当中。
除上面列举的方法外还有一些大家所熟知的顺便一提, 比如关闭没用的rms ,关闭没用的网络连接,关闭没用的流。正确地停止线程。良好的程序架构减少代码偶合性也是一个不错的方法,无论在代码调式,内存释放都可以做到非常清析。
二. 图片优化
j2me的内存杀手无疑非图片莫属,一张3k的图片可以占用20多k的内存不信大家把load前后的内存剩余打印出来对比看看。所以防止内存溢出最直接的办法就是从图片入手。
1.图片压缩: 多数人马上会想到这个办法。不错这个办法是最有效的。在photoshop里图片制作完成后不要选择 "存储为",而是选择 "存储为 web 所用格式" 可以根据里面的选项进行压缩,特别是颜色这一项越小越好不过相应的图像会有所失真。不要认为这样就完了。
实际上该图片还可以再次压缩,在网上有许多类似的工具。推荐一款可以压缩png格式的软件 xat.com Image Optimizer 效果不错。经常都有 70% 的压缩率且图像不会失真。
假如你有多张规格一样的图片,那么建议你把它做成一张长条图片。有两个原因:
1、 这样节省存储空间和内存空间。大家可做个试验将10张图片的内容放在一张当中对比看看文件大小有没有变化。
2 、10张图片需要10个image 对象需要进行10次io操作浪费时间不说还浪费内存。当笔者发现这个好处时兴奋地把所有图片都存成一张,吱地一声内存又溢出了...原因想必大家也知道!!图片太大了不要把不同界面的图片整合在一起否则经常会得不偿失。
作图时还有一些细节需要注意,颜色数量,分辩率,图像模式(最好是索引颜色),画布大小都会影响到图片大小。
三. 工具优化
谁都知道混淆器是用来保护代码的以加大反编译的难度(个人认为这是在嘲笑程序员的智商)。实际上用它来优化程序也是不错的选择,至少有两点好处:
1、 压缩程序大小。一个60k的程序经常可以压掉10k左右。10k的空间对于写低端手机的程序员简直是雪中送碳,多少超过64k限制的游戏都受过它的恩惠;
2、节省内存空间。用脚去想也想得出来代码少了内存里的代码段自然就短了。
「已注销」
2005-09-13
打赏
举报
回复
少用类,接口,包。
homesos
2005-09-13
打赏
举报
回复
应该多注意编写代码时的规范性与可靠性
以免在程序运行期间出现内存溢出等异常
homesos
2005-09-13
打赏
举报
回复
这个也有关系?
我都是这样写滴,
a = x ? 0 : 1;
少用类,能省则省,
最后混淆一下包,比这个来滴快,效果比这个明显多了,呵呵
norains
2005-09-13
打赏
举报
回复
最明显就是少用类!
类用多了,打包就大多了
youngplayer
2005-09-13
打赏
举报
回复
sure! 这个方法我用过!!! 呵呵 可以省好几个字节呢
J2ME
开发入门专题系列之二:
J2ME
应用
程序
与简表
本文围绕
J2ME
为小型设备开发应用
程序
展开,介绍了设计、性能、编译、打包和部署等方面的
注意
事项,如保持
程序
简单、使用局部变量等。还提及
J2ME
简表,包括 KJava 和 MIDP,指出 MIDP 可能取代 KJava。
blackberry平台
J2ME
编程指南(五)
本文介绍了
J2ME
应用
程序
的开发技巧,包括设计
注意
事项、性能优化、编译及部署流程。详细探讨了CLDC和CDC配置的区别及其适用场景。
[转载]
J2ME
开发入门专题系列之二:
J2ME
应用
程序
本文深入探讨了
J2ME
应用
程序
的开发要点,包括设计策略、性能优化、编译及打包部署
注意
事项。强调了为小型设备开发时的简洁性和资源管理,以及服务器负载平衡的重要性。
适用于
J2ME
与Android的GZIP压缩解压缩源代码
本文聚焦于适用于
J2ME
与Android的GZIP压缩解压缩技术。介绍了GZIP压缩原理、与其他技术对比优势,分析两平台资源限制及压缩应用策略。给出ZipUtil类实现压缩解压,阐述静态方法节省内存优势及应用,还探讨DEFLATE算法在大文件处理和网络传输中的应用。
J2ME
应用
程序
与简表(转)
本文围绕
J2ME
为小型设备开发应用
程序
展开,介绍设计开发时要
注意
保持
程序
简单、占用内存少等,开发移动设备应用可让服务器多工作。还提及性能、编译、打包部署等
注意
事项,以及 KJava 和 MIDP 两种简表,指出 MIDP 可能取代 KJava。
J2ME
13,096
社区成员
26,491
社区内容
发帖
与我相关
我的任务
J2ME
Java J2ME
复制链接
扫一扫
分享
社区描述
Java J2ME
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章