浅谈Android AsyncTask内存安全的一种使用方式
问题
内部类和内部匿名类会导致内存泄漏,所以很多时候异步代码写的很多。之后一直在想,异步代码到底应该怎么写。怎么才是规范的写法。怎么才是简洁的写法。
思路
以一个弱引用的接口作为主线程与子线程交流的桥梁。
代码
WeakTask.java
publicclassWeakTaskextendsAsyncTask { privateWeakReference >listenerReference; publicWeakTask(OnWeakTaskListener listener){ this.listenerReference=newWeakReference<>(listener); } @Override protectedTdoInBackground(Void...voids){ if(listenerReference.get()!=null){ returnlistenerReference.get().middle(); }else{ returnnull; } } @Override protectedvoidonPreExecute(){ super.onPreExecute(); if(listenerReference.get()!=null){ listenerReference.get().before(); } } @Override protectedvoidonPostExecute(Tt){ super.onPostExecute(t); if(listenerReference.get()!=null&&t!=null){ listenerReference.get().after(t); } } }
OnWeakTaskListener
publicinterfaceOnWeakTaskListener{ voidbefore(); Tmiddle(); voidafter(Tt); }
使用---->LoginActivity.java
publicclassLoginActivityextendsAppCompatActivityimplementsView.OnClickListener{ @Override protectedvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.login); initLayout(); } privatevoidinitLayout(){ findViewById(R.id.btn_login).setOnClickListener(this); } @Override publicvoidonClick(Viewview){ if(view.getId()==R.id.btn_login){ newWeakTask(newLoginWeakTaskListener()).execute(); } } privateclassLoginWeakTaskListenerimplementsOnWeakTaskListener { @Override publicvoidbefore(){ ...开始前 } @Override publicIntegermiddle(){ ...内部执行 } @Override publicvoidafter(Integerinteger){ ...结果返回后处理 } } }
结论
这几天一直在看rxJava,也一直在思考为什么要学习rxJava,当然,我感觉既然美其名曰观察者模式,那么它应该解决的问题主要在于,让主线程中显示的数据随着子线程中的数据去刷新,之前看过Android官方的mvvm好像是使用了rxJava,尝试着使用了rxJava感觉不到任何优势可言。如果后面有时间,会深入研究一下观察者模式,之后再看看rxJava与rxAndroid,最近又到了秋招的时候,又一次面临求职的难题。。。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。