1

サービスクラスを使用して、毎回バックグラウンドでアプリを実行することにより、アプリケーションを操作しています。サービスクラスはバックグラウンドで実行されます。私のサービスクラスでは、毎回バックグラウンドで実行する時間を使用しました。この場合、エミュレーターでエラーは発生しませんが、実際のデバイスでアプリを実行すると、FATAL EXCEPTION Timer-0 エラーが発生します。

次のようにアプリケーションを実装しました。

 public class RepeatService extends Service
 {
 ArrayList<ShoutMessage> resultMessage;
 private Timer timer = new Timer();
 private static final long UPDATE_INTERVAL = 30000;
 @Override
public IBinder onBind(Intent arg0) {
    return null;
}

@Override
public void onCreate() {

    pollForUpdates();
    super.onCreate();
}  

 private void pollForUpdates() {
    timer.scheduleAtFixedRate(new TimerTask() {
        @Override
        public void run() {


            resultShoutMessage = new ParseXml().convertMessages(new Model().getMessages(getID));

            for(int i=0;i<resultMessage.size();i++)
            {
                String userID = resultMessage.get(i).getUserID();
                String userName = resultMessage.get(i).getUserFirstName();
                String messageID= resultMessage.get(i).getMessageID();
                String userMessage=resultMessage.get(i).getMessageText();


            }

                intent.setAction("com.sample.presentationLayer");
                sendBroadcast(intent); // finally broadcast
        }
    }, 0, UPDATE_INTERVAL);

}


 @Override
public void onDestroy() {
    timer.cancel();

    super.onDestroy();
}

}

上記の実装を実行すると、次のようなエラーが発生します。

 01-01 01:18:34.414: ERROR/AndroidRuntime(2049): FATAL EXCEPTION: Timer-0
 01-01 01:18:34.414: ERROR/AndroidRuntime(2049): java.lang.NullPointerException
 01-01 01:18:34.414: ERROR/AndroidRuntime(2049):     at com.fitzgerald.presentationLayer.RepeatService$1.run(RepeatService.java:63)
01-01 01:18:34.414: ERROR/AndroidRuntime(2049):     at java.util.Timer$TimerImpl.run(Timer.java:289)

アプリケーションで上記の問題を解決するにはどうすればよいですか?

どんな体でも私を助けてください

4

1 に答える 1

1

代わりに、NullPointerExceptionRepeatService.java番号63内の arun()です。解決するだけです。

于 2012-03-06T06:05:19.870 に答える