android性能优化1

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

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

 

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

 

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

 

[c-sharp] view plain copy
  1. class ImageManager {     
  2.     private WeakHashMap<Integer, WeakReference<Bitmap>> mBitmaps;     
  3.     private WeakHashMap<Integer, WeakReference<Drawable》> mDrawables;     
  4.     
  5.     private boolean mActive = true;     
  6.     
  7.     public ImageManager() {     
  8.         mBitmaps = new WeakHashMap<Integer, WeakReference<Bitmap>>();     
  9.         mDrawables = new WeakHashMap<Integer, WeakReference<Drawable>>();     
  10.     }     
  11.     
  12.    
  13.     public Bitmap getBitmap(int resource) {     
  14.         if (mActive) {     
  15.             if (!mBitmaps.containsKey(resource)) {     
  16.                 mBitmaps.put(resource,     
  17.                     new WeakReference<Bitmap>(BitmapFactory.decodeResource(MainActivity.getContext().getResources(), resource)));     
  18.             }     
  19.             return ((WeakReference<Bitmap>)mBitmaps.get(resource)).get();     
  20.         }     
  21.         return null;     
  22.     }     
  23.     
  24.     public Drawable getDrawable(int resource) {     
  25.         if (mActive) {     
  26.             if (!mDrawables.containsKey(resource)) {     
  27.                 mDrawables.put(resource, new WeakReference<Drawable>(getApplication().getResources().getDrawable(resource)));     
  28.             }     
  29.             return ((WeakReference<Drawable>)mDrawables.get(resource)).get();     
  30.         }     
  31.         return null;     
  32.     }     
  33.     
  34.     public void recycleBitmaps() {     
  35.         Iterator itr = mBitmaps.entrySet().iterator();     
  36.         while (itr.hasNext()) {     
  37.             Map.Entry e = (Map.Entry)itr.next();     
  38.             ((WeakReference<Bitmap>) e.getValue()).get().recycle();     
  39.         }     
  40.         mBitmaps.clear();     
  41.     }     
  42.     
  43.     public ImageManager setActive(boolean b) {     
  44.         mActive = b;     
  45.         return this;     
  46.     }     
  47.     
  48.     public boolean isActive() {     
  49.         return mActive;     
  50.     }     
  51. }    

 

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


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

 

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

 

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

 

来看一个表格

 

 

 

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

 

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

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

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

 

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

使用方法如下所示:

[c-sharp] view plain copy
  1. HttpGet request =  
  2.         new HttpGet("http://example.com/gzipcontent");  
  3.     HttpResponse resp =  
  4.         new DefaultHttpClient().execute(request);  
  5.     HttpEntity entity = response.getEntity();  
  6.     InputStream compressed = entity.getContent();  
  7.     InputStream rawData = new GZIPInputStream(compressed);  

 

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

 

[c-sharp] view plain copy
  1. AlarmManager am = (AlarmManager)context.getSystemService(Context.ALARM_SERVICE);  
  2.         Intent intent = new Intent(context, MyService.class);  
  3.         PendingIntent pendingIntent = PendingIntent.getService(context, 0, intent, 0);  
  4.         long interval = DateUtils.MINUTE_IN_MILLIS * 30;  
  5.         long firstWake = System.currentTimeMillis() + interval;  
  6.         am.setRepeating(AlarmManager.RTC,firstWake, interval, pendingIntent); 
目录
相关文章
|
1月前
|
缓存 监控 Android开发
安卓应用性能优化的实用策略
【4月更文挑战第2天】 在竞争激烈的应用市场中,一款应用的性能直接影响用户体验和市场表现。本文针对安卓平台,深入探讨了性能优化的关键要素,包括内存管理、代码效率、UI渲染和电池使用效率。通过分析常见的性能瓶颈,并提供针对性的解决策略,旨在帮助开发者构建更加流畅、高效的安卓应用。
|
4月前
|
Java 调度 数据库
Android 性能优化: 如何进行多线程编程以提高应用性能?
Android 性能优化: 如何进行多线程编程以提高应用性能?
52 0
|
7月前
|
SQL 人工智能 算法
Android性能优化之应用瘦身(APK瘦身)
Android性能优化之应用瘦身(APK瘦身)
|
5天前
|
机器学习/深度学习 人工智能 缓存
安卓应用性能优化实践探索深度学习在图像识别中的应用进展
【4月更文挑战第30天】随着智能手机的普及,移动应用已成为用户日常生活的重要组成部分。对于安卓开发者而言,确保应用流畅、高效地运行在多样化的硬件上是一大挑战。本文将探讨针对安卓平台进行应用性能优化的策略和技巧,包括内存管理、多线程处理、UI渲染效率提升以及电池使用优化,旨在帮助开发者构建更加健壮、响应迅速的安卓应用。 【4月更文挑战第30天】 随着人工智能技术的迅猛发展,深度学习已成为推动计算机视觉领域革新的核心动力。本篇文章将深入分析深度学习技术在图像识别任务中的最新应用进展,并探讨其面临的挑战与未来发展趋势。通过梳理卷积神经网络(CNN)的优化策略、转移学习的实践应用以及增强学习与生成对
|
5天前
|
缓存 移动开发 Android开发
安卓应用性能优化实践指南
【4月更文挑战第30天】在移动开发领域,一个流畅的用户体验是至关重要的。对于安卓开发者来说,理解并实施性能优化策略能够显著提升应用的响应速度和稳定性。本文将深入探讨针对安卓平台的性能瓶颈诊断、内存管理、UI渲染优化以及电池使用效率提升等方面的实用技巧,旨在帮助开发者构建更加高效、响应迅速的安卓应用。
|
6天前
|
缓存 Android开发 iOS开发
打造高效移动应用:Android与iOS性能优化策略
【4月更文挑战第29天】 在移动设备日益成为用户日常互动的主要平台的今天,应用程序的性能已成为决定其成功的关键因素之一。本文将探讨针对Android和iOS平台的性能优化技巧,涵盖内存管理、多线程处理、网络请求优化以及用户界面的流畅性提升等方面。通过分析不同操作系统的架构特点,我们旨在提供一套综合性的策略,帮助开发者构建快速、响应迅捷且用户体验良好的应用。
|
7天前
|
移动开发 API Android开发
Android应用性能优化实战
【4月更文挑战第28天】在移动开发领域,一个流畅的用户体验是至关重要的。对于Android开发者而言,应用的性能优化是一项既挑战性也极其重要的工作。本文将深入探讨Android应用性能优化的多个方面,包括内存管理、UI渲染、多线程处理以及电池效率等,旨在为开发者提供实用的性能提升策略和具体的实施步骤。通过分析常见的性能瓶颈,并结合最新的Android系统特性和工具,我们的目标是帮助读者打造更加高效、响应迅速的Android应用。
|
8天前
|
缓存 监控 Android开发
Android 应用性能优化实战
【4月更文挑战第27天】 在竞争激烈的移动应用市场中,性能优越的应用更能吸引和保留用户。针对Android平台,本文将深入探讨影响应用性能的关键因素,并提供一系列实用的优化策略。我们将从内存管理、UI渲染、多线程处理以及电池使用效率等方面入手,通过具体案例分析如何诊断常见问题,并给出相应的解决方案。文中所提技巧旨在帮助开发者构建更加流畅、高效的Android应用。
20 2
|
12天前
|
移动开发 API 数据处理
构建高效安卓应用:探究Android 12中的新特性与性能优化策略
【4月更文挑战第23天】 随着移动设备的普及,用户对应用程序的性能和效率要求越来越高。安卓系统作为市场占有率最高的移动操作系统之一,其版本更新带来了众多性能提升和新特性。本文将深入探讨Android 12版本中引入的关键性能优化技术,并分析这些技术如何帮助开发者构建更加高效的安卓应用。我们将从最新的运行时权限、后台任务优化、以及电池使用效率等方面入手,提供具体的实践建议,旨在帮助开发者更好地利用这些新工具,以提升应用的响应速度、降低能耗,并最终提高用户的满意度。
|
23天前
|
缓存 Java Android开发
安卓应用性能优化实践
【4月更文挑战第12天】 在竞争激烈的移动应用市场中,性能优越的应用更容易获得用户青睐。本文针对安卓平台,深入分析了影响应用性能的关键因素,并提出了一系列实用的性能优化策略。通过对内存管理、多线程处理、UI渲染等方面的细致调优,开发者可以显著提升应用的响应速度和流畅度,进而提高用户满意度。