启动 ACRA 会导致凌空抽射的其他问题,可能的解决方案?
Posted
技术标签:
【中文标题】启动 ACRA 会导致凌空抽射的其他问题,可能的解决方案?【英文标题】:Initating ACRA causes additional issues with volley, possible fix? 【发布时间】:2016-03-06 18:47:15 【问题描述】:我正在使用 Volley 进行网络通话!此外,我正在使用 LRU 缓存来缓存图像并使用 volley 自己的NetworkImageView
填充。到目前为止一切正常!然而,当我在我的应用程序类中调用初始化 ACRA(崩溃报告器)时,Volley 正在创建 NullPointerException。而且我完全不知道在哪里寻找错误。
这是我的应用程序类的代码。
AppController.class
@ReportsCrashes()
public class AppController extends Application
public static final String TAG = AppController.class.getSimpleName();
private RequestQueue mRequestQueue;
private ImageLoader mImageLoader;
private static AppController mInstance;
@Override
public void onCreate()
super.onCreate();
ACRA.init(this);
public static synchronized AppController getInstance()
return mInstance;
public RequestQueue getRequestQueue()
if (mRequestQueue == null)
mRequestQueue = Volley.newRequestQueue(getApplicationContext());
return mRequestQueue;
public ImageLoader getImageLoader()
getRequestQueue();
if (mImageLoader == null)
mImageLoader = new ImageLoader(this.mRequestQueue,
new LruBitmapCache());
return this.mImageLoader;
public <T> void addToRequestQueue(Request<T> req, String tag)
// set the default tag if tag is empty
req.setTag(TextUtils.isEmpty(tag) ? TAG : tag);
getRequestQueue().add(req);
public <T> void addToRequestQueue(Request<T> req)
req.setTag(TAG);
getRequestQueue().add(req);
public void cancelPendingRequests(Object tag)
if (mRequestQueue != null)
mRequestQueue.cancelAll(tag);
异常是在我的 RecyclerView
的适配器中引发的,我正在填充缓存的项目。
CustomAdapter.class
ImageLoader imageLoader = AppController.getInstance().getImageLoader();
ImageLoader imageLoader2 = AppController.getInstance().getImageLoader();
logcat 的输出是:
E/androidRuntime: 致命异常: main 进程:com.mobloo.eduknow,PID:28295 java.lang.NullPointerException:尝试调用虚拟方法 'com.android.volley.toolbox.ImageLoader com.mobloo.eduknow.AppController.getImageLoader()' 在空对象上 参考 在 com.mobloo.eduknow.CustomAdapter.(CustomAdapter.java:33) 在 com.mobloo.eduknow.FeedsFragment.onCreateView(FeedsFragment.java:57) 在 android.support.v4.app.Fragment.performCreateView(Fragment.java:1962) 在 android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1067) 在 android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1248) 在 android.support.v4.app.BackStackRecord.run(BackStackRecord.java:738) 在 android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1613) 在 android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:570) 在 android.support.v4.app.FragmentPagerAdapter.finishUpdate(FragmentPagerAdapter.java:141) 在 android.support.v4.view.ViewPager.populate(ViewPager.java:1106) 在 android.support.v4.view.ViewPager.populate(ViewPager.java:952) 在 android.support.v4.view.ViewPager.onMeasure(ViewPager.java:1474) 在 android.view.View.measure(View.java:18794) 在 android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:715) 在 android.widget.RelativeLayout.onMeasure(RelativeLayout.java:461) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5951) 在 android.widget.FrameLayout.onMeasure(FrameLayout.java:194) 在 android.support.v7.widget.ContentFrameLayout.onMeasure(ContentFrameLayout.java:135) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5951) 在 android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1465) 在 android.widget.LinearLayout.measureVertical(LinearLayout.java:748) 在 android.widget.LinearLayout.onMeasure(LinearLayout.java:630) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5951) 在 android.widget.FrameLayout.onMeasure(FrameLayout.java:194) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5951) 在 android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1465) 在 android.widget.LinearLayout.measureVertical(LinearLayout.java:748) 在 android.widget.LinearLayout.onMeasure(LinearLayout.java:630) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5951) 在 android.widget.FrameLayout.onMeasure(FrameLayout.java:194) 在 com.android.internal.policy.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2643) 在 android.view.View.measure(View.java:18794) 在 android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2100) 在 android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1216) 在 android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1452) 在 android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1107) 在 android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6013) 在 android.view.Choreographer$CallbackRecord.run(Choreographer.java:858) 在 android.view.Choreographer.doCallbacks(Choreographer.java:670) 在 android.view.Choreographer.doFrame(Choreographer.java:606) 在 android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:844) 在 android.os.Handler.handleCallback(Handler.java:739) 在 android.os.Handler.dispatchMessage(Handler.java:95) 在 android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
那么 ACRA 初始化是否会影响 Volley,从而导致没有正确启动 Volley 以引发 NullPointerException?有什么可能的解决方法?
【问题讨论】:
【参考方案1】:mInstance
是null
,因为你从不给它赋值。这与ACRA无关,可能是您在ACRA中添加时不小心删除了一些代码。
【讨论】:
确实,不小心从onCreate()
中删除了mInstance = this;
以上是关于启动 ACRA 会导致凌空抽射的其他问题,可能的解决方案?的主要内容,如果未能解决你的问题,请参考以下文章
ACRA:如何将 ACRA 报告写入文件(在 SD 卡中)?
ACRA 框架的使用 -- 发送到后台解析(后台的代码也在)
esp32 同时打开蓝牙,wifi和ota后程序过大导致无法启动
安装mysql因为/tmp权限不足而导致ERROR 1045 (28000): Access denied for user root@localhost (using password: NO)的解