2016-02-05 123 views
-2

我在运行应用程序时遇到了一个致命异常:main。它首先运行,但几秒钟就会崩溃。Android - java.lang.RuntimeException:无法从包中读取输入通道文件描述符

这里是我的logcat:

java.lang.RuntimeException: Could not read input channel file descriptors from parcel. 
               at android.view.InputChannel.nativeReadFromParcel(Native Method) 
               at android.view.InputChannel.readFromParcel(InputChannel.java:148) 
               at android.view.IWindowSession$Stub$Proxy.addToDisplay(IWindowSession.java:752) 
               at android.view.ViewRootImpl.setView(ViewRootImpl.java:527) 
               at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:282) 
               at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:85) 
               at android.app.Dialog.show(Dialog.java:298) 
               at android.app.AlertDialog$Builder.show(AlertDialog.java:993) 
               at com.mobext.shakeys.ActivityMain$ProcessData.onPostExecute(ActivityMain.java:545) 
               at com.mobext.shakeys.ActivityMain$ProcessData.onPostExecute(ActivityMain.java:212) 
               at android.os.AsyncTask.finish(AsyncTask.java:636) 
               at android.os.AsyncTask.access$500(AsyncTask.java:177) 
               at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:653) 
               at android.os.Handler.dispatchMessage(Handler.java:102) 
               at android.os.Looper.loop(Looper.java:135) 
               at android.app.ActivityThread.main(ActivityThread.java:5254) 
               at java.lang.reflect.Method.invoke(Native Method) 
               at java.lang.reflect.Method.invoke(Method.java:372) 
               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 

里面我ActivityMain.java:542在alrt.show(),这是其中的logcat点吧:

@Override 
    protected void onPostExecute(Boolean result) { 
     Log.i(TAG, "onPostExecute"); 
     super.onPostExecute(result); 
     if(result){ 

      Log.i(TAG, "TASK IS DONE"); 
      try { 
       PackageInfo pInfo = getPackageManager().getPackageInfo(getPackageName(), 0); 
       app.saveToLastPref(ActivityMain.this, app.PREFS_PREV_VERSION, pInfo.versionName); 
      } catch (NameNotFoundException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
      } 
      Intent intent = new Intent(getApplicationContext(), ActivityMenuPage.class); 
      startActivity(intent); 
      finish(); 
     }else{ 
      ActivityMain.this.deleteDatabase("DBSHAKEYS"); 
      Builder alrt = new AlertDialog.Builder(mcontext); 
      alrt.setMessage("Update failed. Please check your internet connection and try again."); 
      alrt.setPositiveButton("Okay", new OnClickListener() { 

       @Override 
       public void onClick(DialogInterface dialog, int which) { 
        finish(); 
       } 
      }); 
      alrt.show(); 
     } 
    } 

} 

而且在ActivityMain.java: 212:

public class ProcessData extends AsyncTask<Void, Void, Boolean> 
+0

您可能会在调用alrt.show()方法之前显示一些'AlertDialog'。你有没有检查正确?生成器是你的自定义类吗? –

回答

0

我认为Builder是你现在使用的自定义类来显示AlertDialog

以下是可能发生的事情

onPostExecute()方法,你的一些背景,一边完成后,执行自动调用。然后它试图使用Builder类,它可能正在被另一个进程使用,并仍在内存中运行。

那该怎么解决呢?

  1. 回顾你的代码,看看是否已被使用 生成器类所示的对话框。
  2. 只需将此行更改为 Builder alrt = new AlertDialog.Builder(mcontext);即可,通常为AlertDialog.Builder alrt = new AlertDialog.Builder(mcontext); 并查看是否有效。
+0

仍然不工作,先生。谢谢你的答案btw。 – RussVirtuoso

+0

@RussVirtuoso你的mContext是什么?这是你的活动像'MyActivity.this'还是别的? –

+0

@RussVirtuoso只需调试您的应用程序放置'AlertDialog.Builder alrt =新的AlertDialog.Builder(MyActivity.this);'。这应该工作。 –

相关问题