尝试从服务器Android Studio读取文本文件时,应用程序崩溃

时间:2014-07-22 12:29:58

标签: android sdk crash

早些时候,当我开发我的应用程序时,从服务器读取文本文件没有引起任何问题。现在,每当我这样做时,应用程序崩溃并显示“发生意外错误”。我使用的是4.1.2版本的API。

以下是我的主要活动的代码:

package awsomisoft.yemeb;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;


public class Main extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    new Thread() {
        TextView urlTextOut = (TextView) findViewById(R.id.URLtextView);
        StringBuilder text = new StringBuilder();
        @Override
        public void run() {
            try

            {
                String str = "";
                URL url = new URL("myurlhere");

                BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream()));

                while ((str = in.readLine()) != null) {
                    text.append(str);
                }
                in.close();
            } catch (MalformedURLException e1)

            {
            } catch (IOException e)

            {
            }

            urlTextOut.setText(text);
        }
    }.start();
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    if (id == R.id.action_settings) {
        return true;
    }
    return super.onOptionsItemSelected(item);
}
}

我已经在网上看了,大多数解决方案都涉及因为NetworkOnMainThreadException而将读取代码放在新线程中。代码有什么问题导致它崩溃吗?我还确实将权限添加到清单文件(AndroidManifest.xml)。

有没有办法解决这个问题?如果需要更多信息,请询问,我可以提供。

2 个答案:

答案 0 :(得分:1)

我看到你在UI线程中没有更改TextView。请在onCreate()

中找到您的观点
TextView urlTextOut = (TextView) findViewById(R.id.URLtextView);

当您更改文字时:

runOnUiThread(new Runnable() {
            @Override
            public void run() {
                urlTextOut.setText(text);
            }
        });

答案 1 :(得分:0)

  1. 将来,您应该能够在IDE的logcat窗口中查看日志,异常堆栈跟踪等。您是从IDE启动应用程序的,对吧?

  2. 我认为您的具体问题是由于您尝试从UI线程以外的线程访问UI元素这一事实造成的,这是不可能的。您需要将代码放入runOnUiThread()调用中才能使其正常工作。