启动 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.measureChildHorizo​​ntal(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】:

mInstancenull,因为你从不给它赋值。这与ACRA无关,可能是您在ACRA中添加时不小心删除了一些代码。

【讨论】:

确实,不小心从onCreate() 中删除了mInstance = this;

以上是关于启动 ACRA 会导致凌空抽射的其他问题,可能的解决方案?的主要内容,如果未能解决你的问题,请参考以下文章

使用数组从数据库中设置表内的值

ACRA:如何将 ACRA 报告写入文件(在 SD 卡中)?

HTTP 客户端和 REST 客户端的区别

ACRA 框架的使用 -- 发送到后台解析(后台的代码也在)

esp32 同时打开蓝牙,wifi和ota后程序过大导致无法启动

安装mysql因为/tmp权限不足而导致ERROR 1045 (28000): Access denied for user root@localhost (using password: NO)的解