为什么要优化
CPU不快:10-400MHz
内存有限:128k-64M
电力有限
网络连接设置占用时间
大多数开发都是在模拟器上进行的,实际运行又是两码事
微观代码优化:除法上的优化
移动CPU 不需要一个除法指令
intmid = ( hi + lo ) / 2;改为
intmid = ( hi + lo ) >> 1;
有助于提高性能
1、局部变量的赋值性能高于全局变量
2、使用多种选择的Switch 语句比else-if 语句更亲切
3、循环控制
Vector v;
intn = v.size();
for(inti = 0; i < n; ++i ) {}
字符串常数
String str = “China”;
字符串
StringBuffer sb;String str = “China”;for( int i= 1; i <=1 0; i ++) {sb.append(str);}
字符串
String s;if( s.length() == 0 ) {}
StringBuffer sb;for( int i = 0; i < 10; ++i ) {sb.append( i );sb.append( ‘,’);}
4、用StringBuffer比String好
StringBuffer sb = new StringBuffer(“s1”);String str2 = “s2”;sb.append(str2 );
5、异常处理
if( cus == null ) {return;}else{cus.fun();}
内部类
语法上的便利需要开销
内部类提供了很多语法上的便利,但是有着隐藏的开销(额外的方法和类变量)
养成以下习惯
引用不用之后置空
连接最终要关闭,释放资源
MIDlet各个函数的功能分配
成员变量生成和构造函数,在生命周期中执行一次,一般完成资源分配,对象创建
所以:
一般在定义时创建对象,或在构造函数中创建对象,不建议在startApp中创建对象
Pause函数运行之后如果再继续,startApp将会运行,所以你可以在pause中释放一些资源,在startApp中获得
但是要注意保存现场
destroyApp释放所有资源
CPU不快:10-400MHz
内存有限:128k-64M
电力有限
网络连接设置占用时间
大多数开发都是在模拟器上进行的,实际运行又是两码事
微观代码优化:除法上的优化
移动CPU 不需要一个除法指令
intmid = ( hi + lo ) / 2;改为
intmid = ( hi + lo ) >> 1;
有助于提高性能
1、局部变量的赋值性能高于全局变量
2、使用多种选择的Switch 语句比else-if 语句更亲切
3、循环控制
Vector v;
intn = v.size();
for(inti = 0; i < n; ++i ) {}
字符串常数
String str = “China”;
字符串
StringBuffer sb;String str = “China”;for( int i= 1; i <=1 0; i ++) {sb.append(str);}
字符串
String s;if( s.length() == 0 ) {}
StringBuffer sb;for( int i = 0; i < 10; ++i ) {sb.append( i );sb.append( ‘,’);}
4、用StringBuffer比String好
StringBuffer sb = new StringBuffer(“s1”);String str2 = “s2”;sb.append(str2 );
5、异常处理
if( cus == null ) {return;}else{cus.fun();}
内部类
语法上的便利需要开销
内部类提供了很多语法上的便利,但是有着隐藏的开销(额外的方法和类变量)
养成以下习惯
引用不用之后置空
连接最终要关闭,释放资源
MIDlet各个函数的功能分配
成员变量生成和构造函数,在生命周期中执行一次,一般完成资源分配,对象创建
所以:
一般在定义时创建对象,或在构造函数中创建对象,不建议在startApp中创建对象
Pause函数运行之后如果再继续,startApp将会运行,所以你可以在pause中释放一些资源,在startApp中获得
但是要注意保存现场
destroyApp释放所有资源