фатальная ошибка

Ответить
login-l
Сообщения: 6
Зарегистрирован: 07 июн 2016, 22:08

фатальная ошибка

Сообщение login-l » 07 июн 2016, 22:24

Пытаюсь освоить работу с библиотекой Jamod, работаю в Android Studio 2.1.1
нашел пример работы с этой библиотекой, если код с примером поместить в класс Test, метод main_test() и запустить программу на выполнение - всё работает

Код: Выделить всё

package com.example.aleksey.mysecondapp;

/**
 * Created by Aleksey on 01.06.2016.
 */

import java.net.*;
import java.io.*;
import net.wimpi.modbus.*;
import net.wimpi.modbus.msg.*;
import net.wimpi.modbus.io.*;
import net.wimpi.modbus.net.*;
import net.wimpi.modbus.util.*;
import net.wimpi.modbus.procimg.*;

public class Test {
    public static void main_test() {

        InetAddress addr = null;
        TCPMasterConnection con = null;
        WriteCoilRequest do_req = null;
        ModbusTCPTransaction do_trans = null;

        int do_ref = 0;
        int port = Modbus.DEFAULT_PORT;

        try {
            addr = InetAddress.getByName("127.0.0.1");
            con = new TCPMasterConnection(addr);
            con.setPort(port);
            con.connect();

            do_req = new WriteCoilRequest();
            do_req.setReference(10);
            do_req.setUnitID(15);

            do_trans = new ModbusTCPTransaction(con);
            do_trans.setRequest(do_req);
            do_trans.setReconnecting(false);

            do_req.setCoil(true);
            do_trans.execute();

            con.close();
        } catch (Exception ex) {
            ex.printStackTrace();
        }

}

но если метод main_test() вызывать из другого класса, например мне нужно вызывать из обработчика нажатия кнопки:

Код: Выделить всё

package com.example.aleksey.mysecondapp;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;


public class MainActivity extends AppCompatActivity {
    Button button1;
    TextView textView;

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

        button1 = (Button) findViewById(R.id.button1);

        button1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                textView.setText("Нажата кнопка ВВЕРХ");
                //Test.main_test();
            }
        });

    }
}
то программа вылетает с фатальной ошибкой

Код: Выделить всё

06-07 22:04:36.016 22820-22820/com.example.aleksey.mysecondapp E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                 Process: com.example.aleksey.mysecondapp, PID: 22820
                                                                                 java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setText(java.lang.CharSequence)' on a null object reference
                                                                                     at com.example.aleksey.mysecondapp.MainActivity$1.onClick(MainActivity.java:24)
                                                                                     at android.view.View.performClick(View.java:5184)
                                                                                     at android.view.View$PerformClick.run(View.java:20910)
                                                                                     at android.os.Handler.handleCallback(Handler.java:739)
                                                                                     at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                                     at android.os.Looper.loop(Looper.java:145)
                                                                                     at android.app.ActivityThread.main(ActivityThread.java:5944)
                                                                                     at java.lang.reflect.Method.invoke(Native Method)
                                                                                     at java.lang.reflect.Method.invoke(Method.java:372)
                                                                                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1389)
                                                                                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1184)
06-07 22:04:37.606 22820-22820/com.example.aleksey.mysecondapp I/Process: Sending signal. PID: 22820 SIG: 9
Что нужно, чтобы вызвать main_test() из обработчика кнопки?

login-l
Сообщения: 6
Зарегистрирован: 07 июн 2016, 22:08

Re: фатальная ошибка

Сообщение login-l » 08 июн 2016, 08:42

положил библиотеку Jamod в папку Lib своего проекта
добавил в манифест строку
<uses-permission android:name="android.permission.INTERNET"/>

, теперь получаю такую ошибку:

Код: Выделить всё

android.os.NetworkOnMainThreadException
at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147)
at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:110)
at libcore.io.IoBridge.connectErrno(IoBridge.java:137)
at libcore.io.IoBridge.connect(IoBridge.java:122)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:163)
at java.net.Socket.startupSocket(Socket.java:590)
at java.net.Socket.<init>(Socket.java:226)
at net.wimpi.modbus.net.TCPMasterConnection.connect(TCPMasterConnection.java:65)
at com.example.aleksey.myapplication.MainActivity$1.onClick(MainActivity.java:57)
at android.view.View.performClick(View.java:5184)
at android.view.View$PerformClick.run(View.java:20910)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5944)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1389)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1184)
файл манифеста у меня следующий

Код: Выделить всё

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.aleksey.myapplication">

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

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>

подскажите, что требуется?

Аватара пользователя
Foenix
Сообщения: 4201
Зарегистрирован: 20 окт 2012, 12:01

Re: фатальная ошибка

Сообщение Foenix » 08 июн 2016, 10:26

гугли, или по форуму, или хотя бы переведи NetworkOnMainThreadException все сразу станет ясно
R.id.team

NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198

Ответить