5

DBから情報を読み取ってUIに書き込むasyncTaskProcがあります...

コードは Android 4.0 では完全に機能しますが、2.3 では機能しません... コードは次のとおりです

新しい非同期タスク

`public class IceCastPoll extends TimerTask {

    public IceCastPoll() {

    }

    @TargetApi(9)
    public void run() {

        new AsyncTaskProc().execute();   
    }

}`

THE ASYNCTASK の実装

@TargetApi(9)
class AsyncTaskProc extends AsyncTask<Void, String, Void> {
    List<Stream> streams=null;

    @Override
    protected void onPostExecute(Void result) {

        textSong =(TextView) findViewById(R.id.textViewCurrentSong);
        textArtist =(TextView) findViewById(R.id.textViewCurrentArtist);
        textTit=(TextView) findViewById(R.id.textViewTit);
        textArt=(TextView) findViewById(R.id.TextViewArt);
        copertina=(ImageView) findViewById(R.id.imageViewCopertina);
        new DownloadImageTask((ImageView) findViewById(R.id.imageViewCopertina)).execute("http://service.uniradiocesena.it/OnAir.jpg");

        try {
            for (Stream stream: streams) {

                try
                {   
                    //Thread.sleep(5000);
                    //textSong.setText((stream.getCurrentSong()));
                    textArt.setText("Artista:");
                    textTit.setText("Titolo:");
                    StringTokenizer tokens = new StringTokenizer(stream.getCurrentSong(), "-");
                    String first = tokens.nextToken();
                    String second = tokens.nextToken();
                    textSong.setText(first);
                    textArtist.setText(second);

                } catch (Exception e) { 
                    //Thread.sleep(5000);
                    textSong.setText((stream.getCurrentSong()));
                    textArt.setText("Rotazione:");
                    textTit.setText("");
                    textArtist.setText("");
                }
            }
        } catch (Exception e) {

            //Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_SHORT).show();

        }

    }

    @Override
    protected Void doInBackground(Void... unused) {



        Scraper scraper = new IceCastScraper();

        StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
        StrictMode.setThreadPolicy(policy);


        try {
            streams = scraper.scrape(new URI("http://r35798.ovh.net:8000/"));

        } catch (ScrapeException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            //Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_LONG).show();
        } catch (URISyntaxException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            //Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_LONG).show();
        }




        return (null);
    }


}`

LOGCAT エラー

11-07 11:09:49.729: W/dalvikvm(18983): Exception Ljava/lang/RuntimeException; thrown while initializing Landroid/os/AsyncTask;
11-07 11:09:49.729: W/dalvikvm(18983): threadid=9: thread exiting with uncaught exception (group=0x40018560)
11-07 11:09:49.739: E/AndroidRuntime(18983): FATAL EXCEPTION: Timer-0
11-07 11:09:49.739: E/AndroidRuntime(18983): java.lang.ExceptionInInitializerError
11-07 11:09:49.739: E/AndroidRuntime(18983):    at com.example.appuniradiocesena.SwipeyTabsSampleActivity$IceCastPoll.run(SwipeyTabsSampleActivity.java:233)
11-07 11:09:49.739: E/AndroidRuntime(18983):    at     java.util.Timer$TimerImpl.run(Timer.java:284)
11-07 11:09:49.739: E/AndroidRuntime(18983): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
11-07 11:09:49.739: E/AndroidRuntime(18983):    at android.os.Handler.<init>(Handler.java:121)
11-07 11:09:49.739: E/AndroidRuntime(18983):    at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
11-07 11:09:49.739: E/AndroidRuntime(18983):    at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
11-07 11:09:49.739: E/AndroidRuntime(18983):    at android.os.AsyncTask.<clinit>(AsyncTask.java:152)
11-07 11:09:49.739: E/AndroidRuntime(18983):    ... 2 more

どんな提案でも非常に高く評価されます!

そして、英語の間違いを悔やみます :D

4

3 に答える 3

10

メインスレッドで作成されたハンドラーを使用してAsyncTaskを開始する必要があります。したがってrun()、IceCastPollのメソッドを次のメソッドに置き換えます。

private Handler handler = new Handler(Looper.getMainLooper());

@Override
public void run() {
   handler.post(new Runnable() {
      public void run() {
          new AsyncTaskProc().execute();
      }
   });
 }
于 2012-11-07T10:38:04.087 に答える
1
 new AsyncTaskProc().execute();    

このコードをスレッド内に置かないでください。

すでに Handler であるためです。

new AsyncTaskProc().execute(); のように、必要な場所でコードを単純に実行します。もう十分だ

于 2012-11-07T10:28:39.767 に答える
0

findViewById()コード内の 1 つの簡単な提案:特定の間隔で AsyncTask を実行しようとしているため、毎回行うのはなぜですか?

onCreate()代わりに、メソッド内のすべてのビューを見つけてください。

于 2012-11-07T10:32:11.947 に答える