列举下真正意义上的优化:

  1.  ViewHolder   Tag 必不可少,这个不多说!
  2. 如果自定义Item中有涉及到图片等等的,一定要狠狠的处理图片,图片占的内存是ListView项中最恶心的,处理图片的方法大致有以下几种:
    2.1:不要直接拿个路径就去循环decodeFile();这是找死….用Option保存图片大小、不要加载图片到内存去;
    2.2:  拿到的图片一定要经过边界压缩
    2.3:在ListView中取图片时也不要直接拿个路径去取图片,而是以WeakReference(使用WeakReference代替强引用。比如可以使        用WeakReference<Context> mContextRef)、SoftReference、WeakHashMap等的来存储图片信息,是图片信息不是图片哦!
    2.4:在getView中做图片转换时,产生的中间变量一定及时释放,用以下形式:
  3. 尽量避免在BaseAdapter中使用static 来定义全局静态变量,我以为这个没影响 ,这个影响很大,static是Java中的一个关键字,当用它来修饰成员变量时,那么该变量就属于该类,而不是该类的实例。所以用static修饰的变量,它的生命周期是很长的,如果用它来引用一些资源耗费过多的实例(比如Context的情况最多),这时就要尽量避免使用了..
  4. 如果为了满足需求下必须使用Context的话:Context尽量使用Application Context,因为Application的Context的生命周期比较长,引用它不会出现内存泄露的问题
  5. 尽量避免在ListView适配器中使用线程,因为线程产生内存泄露的主要原因在于线程生命周期的不可控制
  6.  记下小马自己的错误:
                 之前使用的自定义ListView中适配数据时使用AsyncTask自行开启线程的,这个比用Thread更危险,因为Thread只有在run函数不 结束时才出现这种内存泄露问题,然而AsyncTask内部的实现机制是运用了线程执行池(ThreadPoolExcutor,要想了解这个类的话大家加下我们的Android开发群五号,因为其它群的存储空间快满了,所以只上传到五群里了,看下小马上传的Gallery源码,你会对线程执行池、软、弱、强引用有个更深入的认识),这个类产生的Thread对象的生命周期是不确定的,是应用程序无法控制的,因此如果AsyncTask作为Activity的内部类,就更容易出现内存泄露的问题。这个问题的解决办法小马当时网上查到了记在txt里了,如下: 
    6.1:将线程的内部类,改为静态内部类。
  7. 6.2:在线程内部采用弱引用保存Context引用
  8. 示例代码如下:
public abstract class WeakAsyncTask<Params, Progress, Result, WeakTarget> extends
	        AsyncTask<Params, Progress, Result> {
	    protected WeakReference<WeakTarget> mTarget;  
 
	    public WeakAsyncTask(WeakTarget target) {
	        mTarget = new WeakReference<WeakTarget>(target);
	    }  
 
	    /** {@inheritDoc} */
	    @Override
	    protected final void onPreExecute() {
	        final WeakTarget target = mTarget.get();
	        if (target != null) {
	            this.onPreExecute(target);
	        }
	    }  
 
	    /** {@inheritDoc} */
	    @Override
	    protected final Result doInBackground(Params... params) {
	        final WeakTarget target = mTarget.get();
	        if (target != null) {
	            return this.doInBackground(target, params);
	        } else {
	            return null;
	        }
	    }  
 
	    /** {@inheritDoc} */
	    @Override
	    protected final void onPostExecute(Result result) {
	        final WeakTarget target = mTarget.get();
	        if (target != null) {
	            this.onPostExecute(target, result);
	        }
	    }  
 
	    protected void onPreExecute(WeakTarget target) {
	        // No default action
	    }  
 
	    protected abstract Result doInBackground(WeakTarget target, Params... params);  
 
	    protected void onPostExecute(WeakTarget target, Result result) {
	        // No default action
	    }
	}