Странное исключение NetworkOnMainThreadException в приложении для Android? - PullRequest
2 голосов
/ 25 января 2012

Идея в том, чтобы начать чат. Итак, у меня есть эти свойства в моем классе:

private MulticastSocket so;
private EditText messageBoard;
private InetAddress serverAddress;
private int port;

Тогда у меня есть этот код в методе onCreate():

protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.second);

    // connect to server
    connect();

    // Associate a variable with the Button on the interface
    final Button sendButton = (Button) findViewById(R.id.button2);
    sendButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            // when the button is clicked the next screen is loaded
            sendMessage();
        }
    });

}   // end of onCreate

Вот мой connect() метод:

private void connect() {

    port = 4456;

    // convert the host name to InetAddress
    try {
        serverAddress = InetAddress.getByName("my server address is here");
    } catch (Exception e) {}

    // create socket and start communicating
    try {
        so = new MulticastSocket(port);
        so.joinGroup(serverAddress);
    } catch (IOException e) {}

    // start listening for incoming messages
    new Receiver(so, messageBoard);
}

Все выглядит правильно для меня, но вот что он говорит:

01-24 23:33:16.277: W/dalvikvm(569): threadid=1: thread exiting with uncaught exception (group=0x409c01f8)
01-24 23:33:16.357: E/AndroidRuntime(569): FATAL EXCEPTION: main
01-24 23:33:16.357: E/AndroidRuntime(569): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.regeduser00x.proj1/com.regeduser00x.proj1.Second}: android.os.NetworkOnMainThreadException
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread.access$600(ActivityThread.java:123)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.os.Looper.loop(Looper.java:137)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread.main(ActivityThread.java:4424)
01-24 23:33:16.357: E/AndroidRuntime(569):  at java.lang.reflect.Method.invokeNative(Native Method)
01-24 23:33:16.357: E/AndroidRuntime(569):  at java.lang.reflect.Method.invoke(Method.java:511)
01-24 23:33:16.357: E/AndroidRuntime(569):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
01-24 23:33:16.357: E/AndroidRuntime(569):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
01-24 23:33:16.357: E/AndroidRuntime(569):  at dalvik.system.NativeStart.main(Native Method)
01-24 23:33:16.357: E/AndroidRuntime(569): Caused by: android.os.NetworkOnMainThreadException
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
01-24 23:33:16.357: E/AndroidRuntime(569):  at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
01-24 23:33:16.357: E/AndroidRuntime(569):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
01-24 23:33:16.357: E/AndroidRuntime(569):  at java.net.InetAddress.getByName(InetAddress.java:295)
01-24 23:33:16.357: E/AndroidRuntime(569):  at com.regeduser00x.proj1.Second.connect(Second.java:99)
01-24 23:33:16.357: E/AndroidRuntime(569):  at com.regeduser00x.proj1.Second.onCreate(Second.java:38)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.Activity.performCreate(Activity.java:4465)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
01-24 23:33:16.357: E/AndroidRuntime(569):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
01-24 23:33:16.357: E/AndroidRuntime(569):  ... 11 more

Это Second.java:99 оказывается serverAddress = InetAddress.getByName("my server address is here");, а строка 38 оказывается connect(); Что с ним? Я проверил строку с InetAddress в небольшой тестовой программе, и она отлично работает, но здесь что-то происходит.

Ответы [ 3 ]

9 голосов
/ 25 января 2012

эта строка:

Caused by: android.os.NetworkOnMainThreadException

Сообщает вам, что происходит.

Вы пытаетесь получить доступ к сетевой функции в главном потоке (UI).начиная с Honeycomb, система создает исключение, когда вы делаете это.

Чтобы исправить это, вам просто нужно переместить любую вещь, касающуюся сети, в собственный поток.

1 голос
/ 06 января 2013

Если вы хотите просто обойти это, укажите минимальную версию SDK Froyo или Gingerbread и пропустите targetSdkVersion:

android:minSdkVersion="8"
1 голос
/ 25 января 2012

Это сделано для того, чтобы вы не блокировали поток пользовательского интерфейса от обработки каких-либо входных событий от пользователя. При блокировании потока пользовательского интерфейса ваше приложение не может выполнять какие-либо процедуры обработки событий.

Обычно в большинстве систем пользовательского интерфейса имеется сторожевой таймер, который отслеживает продолжительную работу в потоке пользовательского интерфейса и блокирует ли поток пользовательского интерфейса более чем на порог (вероятно, 10-20 секунд на устройствах Android в зависимости от производителя / версии ОС ) сторожевой таймер прерывает работу и вызывает всплывающее окно «Приложение не отвечает» (он же ANR).

...