
public List<String> loadInBackground() { // ListVIEw updates properly only if I do this (strange?) mAddresses = new ArrayList<String>(); // ... fill mAddresses ... return mAddresses; } 但是,如果我尝试使用相同的变量,即使它的值发生变化onLoadFinished也会被调用:
public List<String> loadInBackground() { // ListVIEw does not update with this! if(mAddresses == null) { mAddresses = new ArrayList<String>(); } // ... fill mAddresses ... return mAddresses; } 任何人都可以评论这个吗?我是否应该像这样创建一个新对象来返回?是否有任何标志我可以设置“对象已更改,所以即使它是同一个对象,请确保执行所有更新?
解决方法 如果数据已经加载(就像在加载程序中的’mAddresses’变量中那样),则需要调用forceLoad()以使其再次加载:http://developer.android.com/reference/android/content/Loader.html#forceLoad%28%29
编辑:
……经过一番调查……
要回答你原来的问题,无益:’因为它没有’!
从LoaderManager的源代码:
// Notify of the new data so the app can switch out the old data before // we try to destroy it. if (mData != data || !mHaveData) { mData = data; mHaveData = true; if (mStarted) { callOnLoadFinished(loader,data); } } http://grepcode.com/file/repository.grepcode.com/java/ext/com.google.android/android/4.3_r2.1/android/app/LoaderManager.java#LoaderManagerImpl.LoaderInfo.onLoadComplete%28android.content.Loader%2Cjava.lang.Object%29
RE你的问题,我假设你不断在loadInBackground()中添加List而不是清除并重新启动.最干净的方法是每次通过将现有List作为参数传递给ArrayList()构造函数来构建新的ArrayList,它将复制内容.或者您可以覆盖deliverResult(),它从主线程调用,因此修改mAdapter是正常的.或者忘记Loader并使用更简单的AsyncTask …虽然这取决于您的数据实际来自何处.
总结以上是内存溢出为你收集整理的android – AsyncTaskLoader不调用onLoadFinished,除非我在loadInBackground中返回一个新对象全部内容,希望文章能够帮你解决android – AsyncTaskLoader不调用onLoadFinished,除非我在loadInBackground中返回一个新对象所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)