0

送信時にボタンが付いたこのフォームがあります。Yahoo Finance API から株式情報を取得し、それを使用して 3 つのテキストビューに表示します。

私が使っているURL http://download.finance.yahoo.com/d/quotes.csv?s=goog&f=sl1p2

そして私のボタンイベントハンドラは

          URL url;

            try {
                url = new URL("http://download.finance.yahoo.com/d/quotes.csv?s=goog&f=sl1p2");


                InputStream stream = url.openStream();
                BufferedInputStream bis = new BufferedInputStream(stream);
                ByteArrayBuffer bab = new ByteArrayBuffer(50);

                int current = 0;
                   while((current = bis.read()) != -1){
                    bab.append((byte) current);
                   }
                String stockTxt = new String(bab.toByteArray());
                String[] tokens = stockTxt.split(",");

                String stockSymbol = tokens[0];
                String stockPrice = tokens[1];
                String stockChange = tokens[2];

                String fstockSymbol = stockSymbol.substring(1, stockSymbol.length() -1);
                String fstockChange = stockChange.substring(1, stockChange.length()-3);

                symbolOut.setText(fstockSymbol);
                priceOut.setText(stockPrice);
                changeOut.setText(fstockChange);
            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }

したがって、最初の行まで問題がないように見える、つまり url = new URL...,(ブラウザを介して行われた裸の http 要求でさえ、必要な情報を返します)

私のマニフェストエントリは次のようになります

<uses-permission android:name="android.permission.INTERNET"></uses-permission>

以下はlogcatの出力です

05-02 18:36:32.804: D/AndroidRuntime(902): Shutting down VM 05-02 18:36:32.804: W/dalvikvm(902): threadid=1: thread exiting with uncaught exception (group=0x409c01f8) 05-02 18:36:33.113: E/AndroidRuntime(902): FATAL EXCEPTION: main 05-02 18:36:33.113: E/AndroidRuntime(902): android.os.NetworkOnMainThreadException 05-02 18:36:33.113: E/AndroidRuntime(902): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099) 05-02 18:36:33.113: E/AndroidRuntime(902): at java.net.InetAddress.lookupHostByName(InetAddress.java:391) 05-02 18:36:33.113: E/AndroidRuntime(902): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242) 05-02 18:36:33.113: E/AndroidRuntime(902): at java.net.InetAddress.getAllByName(InetAddress.java:220) 05-02 18:36:33.113: E/AndroidRuntime(902): at libcore.net.http.HttpConnection.<init>(HttpConnection.java:71)

だから誰でもどこが間違っているか知っている

4

1 に答える 1

1

これは、LogCat メッセージの主なエラーです --> android.os.NetworkOnMainThreadException. ネットワーク アクセスをバックグラウンド スレッドに移動する必要があります。これを行うには、IntentService、AsynchTask、Handler などを使用できます。

別のスレッドでネットワーク操作を実行することが重要な理由について詳しくは、http://developer.android.com/training/articles/perf-anr.htmlをご覧ください。

于 2013-05-02T13:25:14.127 に答える