2012-03-29 41 views
1

我正在使用AsyncTask从文件中读取数据。我运行应用程序时遇到上述错误。使用AsyncTask时ExceptionInInitializerError

错误消息是:

03-29 20:06:08.445:E/AndroidRuntime(13191): java.lang.ExceptionInInitializerError 03-29 20:06:08.445: E/AndroidRuntime (13191): 在 com.google.app.BouncingBall.HighScore.loadFromFile(HighScore.java:81) 03-29 20:06:08.445:E/AndroidRuntime(13191): 在 com.google.app .BouncingBall.HighScore。(HighScore.java:24)03-29 20:06:08.445:E/AndroidRuntime(13191):在 com.google.app.BouncingBall.Bo uncingBallActivity $ BouncingBallView.init(BouncingBallActivity.java:185) 03-29 20:06:08.445:E/AndroidRuntime(13191):at com.google.app.BouncingBall.BouncingBallActivity $ BouncingBallView.run(BouncingBallActivity.java:173 ) 03-29 20:06:08.445:E/AndroidRuntime(13191):在 java.lang.Thread.run(Thread.java:1019)03-29 20:06:08.445: E/AndroidRuntime(13191) :导致:java.lang.RuntimeException:不能 在未调用Looper.prepare() 03-29 20:06:08.445:E/AndroidRuntime(13191):at android.os的线程内创建处理程序。处理程序。(Handler.java:121)

守则

private void loadFromFile() 
    { 
     new AsyncDataStorage().execute(FILENAME); 
    } 


class AsyncDataStorage extends AsyncTask<String, Integer, Boolean> { 

     protected Boolean doInBackground(String... args) { 
      try { 
       FileInputStream fis = context.openFileInput(FILENAME); 
       byte[] raw = new byte[fis.available()]; 
       String rawData=null; 
       while(fis.read()!=-1) 
       { 
        rawData = new String(raw); 
       } 
       return (processRawData(rawData)); 
      } catch (FileNotFoundException e) { 
       e.printStackTrace(); 
       return false; 
      } catch (IOException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
       return false; 
      } 

     } 
+0

只需将每个对“com.google.app.BouncingBall.HighScore.loadFromFile”的调用或在其中创建的AsyncTask封装到Runnable中,然后将其发布到绑定到UI线程的Handler – 2012-03-29 15:33:55

+0

即可。你能否写下这样的答案,以便我能接受它。 – 2012-03-29 15:43:09

+0

当然,看到我的答案!谢谢! – 2012-03-29 16:03:43

回答

2

只需将每个调用都打包到com.google.app.BouncingBall.HighScore.loadFromFile或在其中创建AsyncTask即可,并将其发布到绑定到UI线程的Handler。

12
03-29 20:06:08.445: E/AndroidRuntime(13191): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 03-29 20:06:08.445: 

报价the documentation for AsyncTask

任务实例必须在UI线程上创建。

在你的木桶里,任务实例没有在主应用程序(a.k.a.,UI)线程上创建,这就是导致这个异常的原因。

+1

谢谢,先生!只是简单易懂的解释。 – Shrikant 2012-10-31 09:12:52

+0

只有在另一个线程中创建AsyncTask时,ExceptionInInitializerError异常是否会发生?或者它也可能发生在其他情况下?我知道这里的日志显示原因是你写的,但我有另一个ExceptionInInitializerError没有显示它。 – 2017-05-31 17:34:16

+0

@androiddeveloper:我不知道 - 检查源代码。 – CommonsWare 2017-05-31 17:38:37

相关问题