Android进阶:性能优化篇 Android进阶:性能优化篇

Android进阶:性能优化篇

分类:Android 性能优化 585人阅读 评论(0) 收藏 举报

一、在使用Gallery控件时,如果载入的图片过多,过大,就很容易出现OutOfMemoryError异常,就是内存溢出。这是因为Android默认分配的内存只有几M,而载入的图片如果是JPG之类的压缩格式,在内存中展开时就会占用大量的空间,也就容易内存溢出。这时可以用下面的方法解决:

[c-sharp] view plain copy
  1. ImageViewi=newImageView(mContext);
  2. BitmapFactory.Optionsoptions=newBitmapFactory.Options();
  3. options.inSampleSize=10;
  4. //貌似这个options的功能是返回缩略图,10即表示长和宽为原来的1/10,即面积为原来的1/100
  5. //缩略图可以减少内存占用
  6. Bitmapbm=BitmapFactory.decodeFile(lis.
  7. get(position).toString(),options);
  8. i.setImageBitmap(bm);
  9. bm.recycle();
  10. //资源回收

二、统一管理位图资源,适时释放资源

[c-sharp] view plain copy
  1. classImageManager{
  2. privateWeakHashMap<Integer,WeakReference<Bitmap>>mBitmaps;
  3. privateWeakHashMap<Integer,WeakReference<Drawable》>mDrawables;
  4. privatebooleanmActive=true;
  5. publicImageManager(){
  6. mBitmaps=newWeakHashMap<Integer,WeakReference<Bitmap>>();
  7. mDrawables=newWeakHashMap<Integer,WeakReference<Drawable>>();
  8. }
  9. publicBitmapgetBitmap(intresource){
  10. if(mActive){
  11. if(!mBitmaps.containsKey(resource)){
  12. mBitmaps.put(resource,
  13. newWeakReference<Bitmap>(BitmapFactory.decodeResource(MainActivity.getContext().getResources(),resource)));
  14. }
  15. return((WeakReference<Bitmap>)mBitmaps.get(resource)).get();
  16. }
  17. returnnull;
  18. }
  19. publicDrawablegetDrawable(intresource){
  20. if(mActive){
  21. if(!mDrawables.containsKey(resource)){
  22. mDrawables.put(resource,newWeakReference<Drawable>(getApplication().getResources().getDrawable(resource)));
  23. }
  24. return((WeakReference<Drawable>)mDrawables.get(resource)).get();
  25. }
  26. returnnull;
  27. }
  28. publicvoidrecycleBitmaps(){
  29. Iteratoritr=mBitmaps.entrySet().iterator();
  30. while(itr.hasNext()){
  31. Map.Entrye=(Map.Entry)itr.next();
  32. ((WeakReference<Bitmap>)e.getValue()).get().recycle();
  33. }
  34. mBitmaps.clear();
  35. }
  36. publicImageManagersetActive(booleanb){
  37. mActive=b;
  38. returnthis;
  39. }
  40. publicbooleanisActive(){
  41. returnmActive;
  42. }
  43. }

三、网络连接往往是耗电量比较大的那我们可以优化一下在需要网络连接的程序中,首先检查网络连接是否正常,如果没有网络连接,那么就不需要执行相应的程序。


检查网络连接的方法如下:

[c-sharp] view plain copy
  1. privatebooleanisConnected(){
  2. ConnectivityManagermConnectivity=(ConnectivityManager)this.getSystemService(CONNECTIVITY_SERVICE);
  3. TelephonyManagermTelephony=(TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
  4. //检查网络连接,如果无网络可用,就不需要进行连网操作等
  5. NetworkInfoinfo=mConnectivity.getActiveNetworkInfo();
  6. if(info==null||
  7. !mConnectivity.getBackgroundDataSetting()){
  8. returnfalse;
  9. }
  10. //判断网络连接类型,只有在3G或wifi里进行一些数据更新。
  11. intnetType=info.getType();
  12. intnetSubtype=info.getSubtype();
  13. if(netType==ConnectivityManager.TYPE_WIFI){
  14. returninfo.isConnected();
  15. }elseif(netType==ConnectivityManager.TYPE_MOBILE
  16. &&netSubtype==TelephonyManager.NETWORK_TYPE_UMTS
  17. &&!mTelephony.isNetworkRoaming()){
  18. returninfo.isConnected();
  19. }else{
  20. returnfalse;
  21. }
  22. }

四、网络间的数据传输也是非常耗费资源的,这包括传输方式和解析方式

来看一个表格

其中 Tree Parse 是DOM解析 Event/Stream是SAX方式解析

很明显,使用流的方式解析效率要高一些,因为DOM解析是在对整个文档读取完后,再根据节点层次等再组织起来。而流的方式是边读取数据边解析,数据读取完后,解析也就完毕了。

在数据格式方面,JSON和Protobuf效率明显比XML好很多,XML和JSON大家都很熟悉。

从上面的图中我们可以得出结论就是尽量使用SAX等边读取边解析的方式来解析数据,针对移动设备,最好能使用JSON之类的轻量级数据格式为佳。

五、传输数据经过压缩目前大部门网站都支持GZIP压缩,所以在进行大数据量下载时,尽量使用GZIP方式下载,可以减少网络流量。

使用方法如下所示:

[c-sharp] view plain copy
  1. HttpGetrequest=
  2. newHttpGet("http://example.com/gzipcontent");
  3. HttpResponseresp=
  4. newDefaultHttpClient().execute(request);
  5. HttpEntityentity=response.getEntity();
  6. InputStreamcompressed=entity.getContent();
  7. InputStreamrawData=newGZIPInputStream(compressed);

六、有效管理Service 后台服务就相当于一个持续运行的Acitivity 如果开发的程序后台都会一个service不停的去服务器上更新数据,在不更新数据的时候就让它sleep,这种方式是非常耗电的,通常情况下,我们可以使用AlarmManager来定时启动服务。如下所示,第30分钟执行一次。

[c-sharp] view plain copy
  1. AlarmManageram=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
  2. Intentintent=newIntent(context,MyService.class);
  3. PendingIntentpendingIntent=PendingIntent.getService(context,0,intent,0);
  4. longinterval=DateUtils.MINUTE_IN_MILLIS*30;
  5. longfirstWake=System.currentTimeMillis()+interval;
  6. am.setRepeating(AlarmManager.RTC,firstWake,interval,pendingIntent);

开发过程中应该注意一些细节,并经手机的整体性能和续航都是有很大的局限,很多个优化的细节会对软件产生本质的影响,这些需要引起重视,也要在开发过程中不断积累

一、在使用Gallery控件时,如果载入的图片过多,过大,就很容易出现OutOfMemoryError异常,就是内存溢出。这是因为Android默认分配的内存只有几M,而载入的图片如果是JPG之类的压缩格式,在内存中展开时就会占用大量的空间,也就容易内存溢出。这时可以用下面的方法解决:

[c-sharp] view plain copy
  1. ImageViewi=newImageView(mContext);
  2. BitmapFactory.Optionsoptions=newBitmapFactory.Options();
  3. options.inSampleSize=10;
  4. //貌似这个options的功能是返回缩略图,10即表示长和宽为原来的1/10,即面积为原来的1/100
  5. //缩略图可以减少内存占用
  6. Bitmapbm=BitmapFactory.decodeFile(lis.
  7. get(position).toString(),options);
  8. i.setImageBitmap(bm);
  9. bm.recycle();
  10. //资源回收

二、统一管理位图资源,适时释放资源

[c-sharp] view plain copy
  1. classImageManager{
  2. privateWeakHashMap<Integer,WeakReference<Bitmap>>mBitmaps;
  3. privateWeakHashMap<Integer,WeakReference<Drawable》>mDrawables;
  4. privatebooleanmActive=true;
  5. publicImageManager(){
  6. mBitmaps=newWeakHashMap<Integer,WeakReference<Bitmap>>();
  7. mDrawables=newWeakHashMap<Integer,WeakReference<Drawable>>();
  8. }
  9. publicBitmapgetBitmap(intresource){
  10. if(mActive){
  11. if(!mBitmaps.containsKey(resource)){
  12. mBitmaps.put(resource,
  13. newWeakReference<Bitmap>(BitmapFactory.decodeResource(MainActivity.getContext().getResources(),resource)));
  14. }
  15. return((WeakReference<Bitmap>)mBitmaps.get(resource)).get();
  16. }
  17. returnnull;
  18. }
  19. publicDrawablegetDrawable(intresource){
  20. if(mActive){
  21. if(!mDrawables.containsKey(resource)){
  22. mDrawables.put(resource,newWeakReference<Drawable>(getApplication().getResources().getDrawable(resource)));
  23. }
  24. return((WeakReference<Drawable>)mDrawables.get(resource)).get();
  25. }
  26. returnnull;
  27. }
  28. publicvoidrecycleBitmaps(){
  29. Iteratoritr=mBitmaps.entrySet().iterator();
  30. while(itr.hasNext()){
  31. Map.Entrye=(Map.Entry)itr.next();
  32. ((WeakReference<Bitmap>)e.getValue()).get().recycle();
  33. }
  34. mBitmaps.clear();
  35. }
  36. publicImageManagersetActive(booleanb){
  37. mActive=b;
  38. returnthis;
  39. }
  40. publicbooleanisActive(){
  41. returnmActive;
  42. }
  43. }

三、网络连接往往是耗电量比较大的那我们可以优化一下在需要网络连接的程序中,首先检查网络连接是否正常,如果没有网络连接,那么就不需要执行相应的程序。


检查网络连接的方法如下:

[c-sharp] view plain copy
  1. privatebooleanisConnected(){
  2. ConnectivityManagermConnectivity=(ConnectivityManager)this.getSystemService(CONNECTIVITY_SERVICE);
  3. TelephonyManagermTelephony=(TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
  4. //检查网络连接,如果无网络可用,就不需要进行连网操作等
  5. NetworkInfoinfo=mConnectivity.getActiveNetworkInfo();
  6. if(info==null||
  7. !mConnectivity.getBackgroundDataSetting()){
  8. returnfalse;
  9. }
  10. //判断网络连接类型,只有在3G或wifi里进行一些数据更新。
  11. intnetType=info.getType();
  12. intnetSubtype=info.getSubtype();
  13. if(netType==ConnectivityManager.TYPE_WIFI){
  14. returninfo.isConnected();
  15. }elseif(netType==ConnectivityManager.TYPE_MOBILE
  16. &&netSubtype==TelephonyManager.NETWORK_TYPE_UMTS
  17. &&!mTelephony.isNetworkRoaming()){
  18. returninfo.isConnected();
  19. }else{
  20. returnfalse;
  21. }
  22. }

四、网络间的数据传输也是非常耗费资源的,这包括传输方式和解析方式

来看一个表格

其中 Tree Parse 是DOM解析 Event/Stream是SAX方式解析

很明显,使用流的方式解析效率要高一些,因为DOM解析是在对整个文档读取完后,再根据节点层次等再组织起来。而流的方式是边读取数据边解析,数据读取完后,解析也就完毕了。

在数据格式方面,JSON和Protobuf效率明显比XML好很多,XML和JSON大家都很熟悉。

从上面的图中我们可以得出结论就是尽量使用SAX等边读取边解析的方式来解析数据,针对移动设备,最好能使用JSON之类的轻量级数据格式为佳。

五、传输数据经过压缩目前大部门网站都支持GZIP压缩,所以在进行大数据量下载时,尽量使用GZIP方式下载,可以减少网络流量。

使用方法如下所示:

[c-sharp] view plain copy
  1. HttpGetrequest=
  2. newHttpGet("http://example.com/gzipcontent");
  3. HttpResponseresp=
  4. newDefaultHttpClient().execute(request);
  5. HttpEntityentity=response.getEntity();
  6. InputStreamcompressed=entity.getContent();
  7. InputStreamrawData=newGZIPInputStream(compressed);

六、有效管理Service 后台服务就相当于一个持续运行的Acitivity 如果开发的程序后台都会一个service不停的去服务器上更新数据,在不更新数据的时候就让它sleep,这种方式是非常耗电的,通常情况下,我们可以使用AlarmManager来定时启动服务。如下所示,第30分钟执行一次。

[c-sharp] view plain copy
  1. AlarmManageram=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
  2. Intentintent=newIntent(context,MyService.class);
  3. PendingIntentpendingIntent=PendingIntent.getService(context,0,intent,0);
  4. longinterval=DateUtils.MINUTE_IN_MILLIS*30;
  5. longfirstWake=System.currentTimeMillis()+interval;
  6. am.setRepeating(AlarmManager.RTC,firstWake,interval,pendingIntent);

开发过程中应该注意一些细节,并经手机的整体性能和续航都是有很大的局限,很多个优化的细节会对软件产生本质的影响,这些需要引起重视,也要在开发过程中不断积累

一、在使用Gallery控件时,如果载入的图片过多,过大,就很容易出现OutOfMemoryError异常,就是内存溢出。这是因为Android默认分配的内存只有几M,而载入的图片如果是JPG之类的压缩格式,在内存中展开时就会占用大量的空间,也就容易内存溢出。这时可以用下面的方法解决:

[c-sharp] view plain copy
  1. ImageViewi=newImageView(mContext);
  2. BitmapFactory.Optionsoptions=newBitmapFactory.Options();
  3. options.inSampleSize=10;
  4. //貌似这个options的功能是返回缩略图,10即表示长和宽为原来的1/10,即面积为原来的1/100
  5. //缩略图可以减少内存占用
  6. Bitmapbm=BitmapFactory.decodeFile(lis.
  7. get(position).toString(),options);
  8. i.setImageBitmap(bm);
  9. bm.recycle();
  10. //资源回收

二、统一管理位图资源,适时释放资源

[c-sharp] view plain copy
  1. classImageManager{
  2. privateWeakHashMap<Integer,WeakReference<Bitmap>>mBitmaps;
  3. privateWeakHashMap<Integer,WeakReference<Drawable》>mDrawables;
  4. privatebooleanmActive=true;
  5. publicImageManager(){
  6. mBitmaps=newWeakHashMap<Integer,WeakReference<Bitmap>>();
  7. mDrawables=newWeakHashMap<Integer,WeakReference<Drawable>>();
  8. }
  9. publicBitmapgetBitmap(intresource){
  10. if(mActive){
  11. if(!mBitmaps.containsKey(resource)){
  12. mBitmaps.put(resource,
  13. newWeakReference<Bitmap>(BitmapFactory.decodeResource(MainActivity.getContext().getResources(),resource)));
  14. }
  15. return((WeakReference<Bitmap>)mBitmaps.get(resource)).get();
  16. }
  17. returnnull;
  18. }
  19. publicDrawablegetDrawable(intresource){
  20. if(mActive){
  21. if(!mDrawables.containsKey(resource)){
  22. mDrawables.put(resource,newWeakReference<Drawable>(getApplication().getResources().getDrawable(resource)));
  23. }
  24. return((WeakReference<Drawable>)mDrawables.get(resource)).get();
  25. }
  26. returnnull;
  27. }
  28. publicvoidrecycleBitmaps(){
  29. Iteratoritr=mBitmaps.entrySet().iterator();
  30. while(itr.hasNext()){
  31. Map.Entrye=(Map.Entry)itr.next();
  32. ((WeakReference<Bitmap>)e.getValue()).get().recycle();
  33. }
  34. mBitmaps.clear();
  35. }
  36. publicImageManagersetActive(booleanb){
  37. mActive=b;
  38. returnthis;
  39. }
  40. publicbooleanisActive(){
  41. returnmActive;
  42. }
  43. }

三、网络连接往往是耗电量比较大的那我们可以优化一下在需要网络连接的程序中,首先检查网络连接是否正常,如果没有网络连接,那么就不需要执行相应的程序。


检查网络连接的方法如下:

[c-sharp] view plain copy
  1. privatebooleanisConnected(){
  2. ConnectivityManagermConnectivity=(ConnectivityManager)this.getSystemService(CONNECTIVITY_SERVICE);
  3. TelephonyManagermTelephony=(TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
  4. //检查网络连接,如果无网络可用,就不需要进行连网操作等
  5. NetworkInfoinfo=mConnectivity.getActiveNetworkInfo();
  6. if(info==null||
  7. !mConnectivity.getBackgroundDataSetting()){
  8. returnfalse;
  9. }
  10. //判断网络连接类型,只有在3G或wifi里进行一些数据更新。
  11. intnetType=info.getType();
  12. intnetSubtype=info.getSubtype();
  13. if(netType==ConnectivityManager.TYPE_WIFI){
  14. returninfo.isConnected();
  15. }elseif(netType==ConnectivityManager.TYPE_MOBILE
  16. &&netSubtype==TelephonyManager.NETWORK_TYPE_UMTS
  17. &&!mTelephony.isNetworkRoaming()){
  18. returninfo.isConnected();
  19. }else{
  20. returnfalse;
  21. }
  22. }

四、网络间的数据传输也是非常耗费资源的,这包括传输方式和解析方式

来看一个表格

其中 Tree Parse 是DOM解析 Event/Stream是SAX方式解析

很明显,使用流的方式解析效率要高一些,因为DOM解析是在对整个文档读取完后,再根据节点层次等再组织起来。而流的方式是边读取数据边解析,数据读取完后,解析也就完毕了。

在数据格式方面,JSON和Protobuf效率明显比XML好很多,XML和JSON大家都很熟悉。

从上面的图中我们可以得出结论就是尽量使用SAX等边读取边解析的方式来解析数据,针对移动设备,最好能使用JSON之类的轻量级数据格式为佳。

五、传输数据经过压缩目前大部门网站都支持GZIP压缩,所以在进行大数据量下载时,尽量使用GZIP方式下载,可以减少网络流量。

使用方法如下所示:

[c-sharp] view plain copy
  1. HttpGetrequest=
  2. newHttpGet("http://example.com/gzipcontent");
  3. HttpResponseresp=
  4. newDefaultHttpClient().execute(request);
  5. HttpEntityentity=response.getEntity();
  6. InputStreamcompressed=entity.getContent();
  7. InputStreamrawData=newGZIPInputStream(compressed);

六、有效管理Service 后台服务就相当于一个持续运行的Acitivity 如果开发的程序后台都会一个service不停的去服务器上更新数据,在不更新数据的时候就让它sleep,这种方式是非常耗电的,通常情况下,我们可以使用AlarmManager来定时启动服务。如下所示,第30分钟执行一次。

[c-sharp] view plain copy
  1. AlarmManageram=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
  2. Intentintent=newIntent(context,MyService.class);
  3. PendingIntentpendingIntent=PendingIntent.getService(context,0,intent,0);
  4. longinterval=DateUtils.MINUTE_IN_MILLIS*30;
  5. longfirstWake=System.currentTimeMillis()+interval;
  6. am.setRepeating(AlarmManager.RTC,firstWake,interval,pendingIntent);

开发过程中应该注意一些细节,并经手机的整体性能和续航都是有很大的局限,很多个优化的细节会对软件产生本质的影响,这些需要引起重视,也要在开发过程中不断积累

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值