致命异常:java.lang.RuntimeException:系统失败

Posted

技术标签:

【中文标题】致命异常:java.lang.RuntimeException:系统失败【英文标题】:Fatal Exception: java.lang.RuntimeException: Failure from system 【发布时间】:2017-06-08 20:32:36 【问题描述】:

我在 crashlytics 报告中经常收到此异常,不知道为什么?

 Fatal Exception: java.lang.RuntimeException: Failure from system
   at android.app.Instrumentation.execStartActivity(Instrumentation.java:1547)
   at android.app.Activity.startActivityForResult(Activity.java:4283)
   at android.app.Activity.startActivityForResult(Activity.java:4230)
   at android.support.v4.app.FragmentActivity.startActivityForResult(Unknown Source)
   at android.app.Activity.startActivity(Activity.java:4567)
   at android.app.Activity.startActivity(Activity.java:4535)
   at com.app.Register.MainActivity.onClick(Unknown Source)
   at android.view.View.performClick(View.java:5702)
   at android.widget.TextView.performClick(TextView.java:10887)
   at android.view.View$PerformClick.run(View.java:22533)
   at android.os.Handler.handleCallback(Handler.java:739)
   at android.os.Handler.dispatchMessage(Handler.java:95)
   at android.os.Looper.loop(Looper.java:158)
   at android.app.ActivityThread.main(ActivityThread.java:7224)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Caused by android.os.TransactionTooLargeException: data parcel size 8177736 bytes
   at android.os.BinderProxy.transactNative(Binder.java)
   at android.os.BinderProxy.transact(Binder.java:503)
   at android.app.ActivityManagerProxy.startActivity(ActivityManagerNative.java:3130)
   at android.app.Instrumentation.execStartActivity(Instrumentation.java:1540)
   at android.app.Activity.startActivityForResult(Activity.java:4283)
   at android.app.Activity.startActivityForResult(Activity.java:4230)
   at android.support.v4.app.FragmentActivity.startActivityForResult(Unknown Source)
   at android.app.Activity.startActivity(Activity.java:4567)
   at android.app.Activity.startActivity(Activity.java:4535)
   at ca.dailydelivery.driver.Register.AdditionalInfoActivity.onClick(Unknown Source)
   at android.view.View.performClick(View.java:5702)
   at android.widget.TextView.performClick(TextView.java:10887)
   at android.view.View$PerformClick.run(View.java:22533)
   at android.os.Handler.handleCallback(Handler.java:739)
   at android.os.Handler.dispatchMessage(Handler.java:95)
   at android.os.Looper.loop(Looper.java:158)
   at android.app.ActivityThread.main(ActivityThread.java:7224)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

我在这个产生崩溃的活动中做的是传递 Intent 以从相机或图库中捕获图像。

代码:

 private void captureImage() 
    Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
    intent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri);
    // start the image capture Intent
    startActivityForResult(intent, CAMERA_CAPTURE_IMAGE_REQUEST_CODE);


private void openGallery() 
    Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
    photoPickerIntent.setType("image/*");
    startActivityForResult(photoPickerIntent, IMAGE_PICK_GALLERY);

请建议如何解决此问题。谢谢

【问题讨论】:

你想做什么? @ShaartiKAKA 为什么会出现问题以及如何解决问题 用大图测试 :) 手机的操作系统版本是多少?如果是牛轧糖,这可能会有所帮助 - [***.com/questions/39098590/… 你想要实现你提供的代码还不足以得到你在做什么 //// 【参考方案1】:

减少您从相机拍摄的图像大小,然后发送到其他活动。因为当我们传递值时,它对交易有一些限制。

Binder 事务缓冲区有一个有限的固定大小,目前为 1Mb,由进程正在进行的所有事务共享。因此,当有许多事务正在进行时,即使大多数单个事务的大小适中,也可能会引发此异常。

更多详情TransactionTooLargeException

【讨论】:

【参考方案2】:

在远程过程调用期间,调用的参数和返回值作为 Parcel 对象传输,存储在 Binder 事务缓冲区中。如果参数或返回值太大而无法放入事务缓冲区,则调用将失败并抛出TransactionTooLargeException

避免TransactionTooLargeException 的关键是保持所有事务相对较小。尽量减少为远程过程调用的参数和返回值创建Parcel 所需的内存量。避免传输大量字符串或大型位图。如果可能,请尝试将大请求分解为更小的部分。

Reference

【讨论】:

【参考方案3】:

创建一个公共类并将位图传递给它,然后在第二个活动中从该公共类中获取位图值。

import android.graphics.Bitmap;

public class BitmapTransfer 
    public static Bitmap bitmap = null;

【讨论】:

以上是关于致命异常:java.lang.RuntimeException:系统失败的主要内容,如果未能解决你的问题,请参考以下文章

java.lang.RuntimeException: Parcelable 遇到 IOException 写入可序列化

Android ProgressDialog 不能与 AsyncTask 一起使用

如何将数据从 Spark SQL 导出到 CSV

Ionic/Cordova 应用程序找不到 MainActivity

troubshooting-sqoop 导出 TiDB表数据报com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communicatio

获取“致命异常 AsyncTask #1”