内存——静态变量导致内存泄漏

转载 2016年08月29日 13:54:18

转自http://blog.csdn.net/u012810020/article/details/51726699

1、要不怎么说static关键字要慎用呢?来看看下面这段代码,Context对象为静态的,那么Activity就无法正常销毁,会常驻内存。

    public class MainActivity extends Activity{  
        public static Context mContext;  
        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            setContentView(R.layout.activity_main);  
            mContext = this;  
        }  
    }  
解决办法:1使用Application的Context。 2慎用statistic关键字


2、单例模式导致内存的泄漏

静态变量导致的内存泄漏太过明显,而单例模式带来的内存的泄漏容易被忽略。

    **  
     * Created by lizhenya.  
     */  
    public class DensityConvertUtils {  
        private DensityConvertUtils() {  
            /* cannot be instantiated */  
            throw new UnsupportedOperationException("cannot be instantiated");  
        }  
      
        /**  
         * dp转px  
         *  
         * @param context  
         * @param dpVal  
         * @return  
         */  
        public static int dp2px(Context context, float dpVal) {  
            return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,  
                    dpVal, context.getResources().getDisplayMetrics());  
        }  
      
        /**  
         * sp转px  
         *  
         * @param context  
         * @param spVal  
         * @return  
         */  
        public static int sp2px(Context context, float spVal) {  
            return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_SP,  
                    spVal, context.getResources().getDisplayMetrics());  
        }  
    }  

我们在使用的时候经常会犯一些错误:

    /**  
     * Created by lizhenya.  
     */  
    public class HomeActivity extends Activity {  
        Button btn_home;  
        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            requestWindowFeature(Window.FEATURE_NO_TITLE);  
            setContentView(R.layout.layout_home);  
            DensityConvertUtils.dp2px(HomeActivity.this,20);  
        }  
    }  
单例模式的特点就是它的生命周期和Application一样,那么如果某个Activity实例被一个单例所持有,也就是说在单例里面引用了它,那么就会造成Activity对象无法正常回收释放。所以我们尽量的使用Application的全局Context。


3,属性动画导致的内存泄漏

    从Android3.0开始,Google提供了属性动画,属性动画中有一类无限循环的动画,如果在Activity中播放此类动画并且在onDestroy()方法中没有停止该动画,那么动画会一直循环下去,尽管在界面上已经无法看不到动画了,但这个时候Activity的View会被动画持有,而View又持有Activity,最终Activity无法释放。下面的动画是无限循环的,会泄露当前的Activity。

    /**  
     * Created by lizhenya.  
     */  
    public class HomeActivity extends Activity {  
        Button btn_home;  
      
        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            requestWindowFeature(Window.FEATURE_NO_TITLE);  
            setContentView(R.layout.layout_home);  
            btn_home = (Button) findViewById(R.id.btn_home);  
            ObjectAnimator animator = ObjectAnimator.ofFloat(btn_home, "ratation", 0, 360).setDuration(2000);  
            animator.setRepeatCount(ValueAnimator.INFINITE);  
            animator.start();  
        }  
    }  

解决方案:

    在当前Activity的onDestroy()方法中取消动画:animator.cancel()。

    /**  
     * Created by lizhenya.  
     */  
    public class HomeActivity extends Activity {  
        private Button btn_home;  
        private ObjectAnimator animator;  
      
        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            requestWindowFeature(Window.FEATURE_NO_TITLE);  
            setContentView(R.layout.layout_home);  
            btn_home = (Button) findViewById(R.id.btn_home);  
      
            animator = ObjectAnimator.ofFloat(btn_home, "ratation", 0, 360).setDuration(2000);  
            animator.setRepeatCount(ValueAnimator.INFINITE);  
            animator.start();  
        }  
      
        @Override  
        protected void onDestroy() {  
            super.onDestroy();  
            animator.cancel();  
        }  
    }  




相关文章推荐

单例造成的内存泄漏

由于单例的静态特性使得其生命周期跟应用的生命周期一样长,所以如果使用不恰当的话,很容易造成内存泄漏。比如下面一个典型的例子,public class AppManager { private...

static关键字所导致的内存泄漏问题

转载自:http://blog.csdn.net/lovejavasman/article/details/52643089 大家都知道内存泄漏和内存溢出是不一样的,内存泄漏所导致的越来越多的内...

C#内存泄露与资源释放 经验总结

经验总结:C#并不是有了垃圾回收机制,你就可以对内存管理放任不管,其实在稍不注意的时候,可能就造成了内存泄露,或者超大内存占用~ 以下记录下遇到过的内存优化-内存泄露的问题与应对方案。 1...
  • Yokeqi
  • Yokeqi
  • 2014-11-13 18:39
  • 8280

c# -- 对象销毁和垃圾回收

The power of ASP.NET C#, ASP.NET(MVC), ADO.NET, JavaScript(JQuery),WCF,SQL server, Windows server,...

内存泄漏优化---静态变量导致内存泄漏

1、要不怎么说static关键字要慎用呢?来看看下面这段代码,Context对象为静态的,那么Activity就无法正常销毁,会常驻内存。 public class MainActivity ext...

Android开发常见的Activity中内存泄漏及解决办法

上一篇文章楼主提到由Context引发的内存泄漏,在这一篇文章里,我们来谈谈Android开发中常见的Activity内存泄漏及解决办法。本文将会以“为什么”“怎么解决”的方式来介绍这几种内存泄漏。 ...

android中不小心使用静态变量会导致内存泄露

在android 项目开发过程中,不小心可能就会导致activity的内存泄露,即使用户在使用APP的时候并没有感受到内存泄露给APP带来毁灭性的奔溃,但我们开发者可以通过调试能够很明显的看到有些占用...
  • wuchuy
  • wuchuy
  • 2016-04-25 15:39
  • 2574

【JAVA优化编程】内存管理之——(5)共享静态变量存储空间

5  共享静态变量存储空间     我们知道类中的静态变量(Static Variable)在程序运行期间其内存空间对所有该类的对象实例而言是共享的,因此在某些时候为了节省系统内存开销,共享资源,将...

c++数据结构—————静态链表防止内存泄漏

**在写静态链表的时候如果new了一个新的动态数组来做数组增长,不及时删除原数组 在短期内不会太大影响 但是积累会造成内存泄漏(大量的堆内存被没有引用的new数组占据) 所以要及时释放掉new的动态数...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)