Сокеты, потоки и сервисы в андроиде, как заставить их работать вместе?

Я столкнулся с проблемой с потоками и сокетами, я не могу понять это, если кто-то может мне помочь, пожалуйста, я был бы очень признателен.

Есть факты :

У меня есть класс обслуживания NetworkService, внутри этого класса у меня есть атрибут Socket. Я хотел бы, чтобы он был в состоянии подключения на протяжении всего жизненного цикла службы.

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

Проблема в том, что в потоке, где я подключаю свой сокет, все в порядке, он подключен, и я могу общаться со своим сервером, как только этот поток закончится, и я попытаюсь повторно использовать сокет, в другом потоке у меня есть сообщение об ошибке Socket is not connected.

Вопросы: - Отключается ли сокет автоматически в конце потока? - Можем ли мы в любом случае передать значение из вызываемого потока вызывающему?

Большое спасибо,

Вот мой код

  public class NetworkService extends Service {

        private Socket  mSocket = new Socket();


  private void _connectSocket(String addr, int port) {
        Runnable connect = new connectSocket(this.mSocket, addr, port);
        new Thread(connect).start();

  }

  private void _authentification() {
        Runnable auth = new authentification();
        new Thread(auth).start();
  }


  private INetwork.Stub mBinder = new INetwork.Stub() {

        @Override
        public int doConnect(String addr, int port) throws RemoteException {
            _connectSocket(addr, port);
            _authentification();
            return 0;
        }
    };


class connectSocket implements Runnable {
        String  addrSocket;
        int portSocket;
        int TIMEOUT=5000;

        public connectSocket(String addr, int port) {
            addrSocket = addr;
            portSocket = port;
        }

        @Override
        public void run() {

            SocketAddress socketAddress = new InetSocketAddress(addrSocket, portSocket);
            try {
                mSocket.connect(socketAddress, TIMEOUT);
                PrintWriter out = new PrintWriter(mSocket.getOutputStream(), true);
                out.println("test42");
                            Log.i("connectSocket()", "Connection Succesful");
            } catch (IOException e) {
                Log.e("connectSocket()", e.getMessage());
                e.printStackTrace();
            }       
        }
    }

    class authentification implements Runnable {

        private String constructFirstConnectQuery() {
            String query = "toto";
            return query;
        }

        @Override
        public void run() {
            BufferedReader  in;
            PrintWriter out;
            String      line = "";

            try {

                in = new BufferedReader(new InputStreamReader(mSocket.getInputStream()));
                out = new PrintWriter(mSocket.getOutputStream(), true);
                out.println(constructFirstConnectQuery());


                while (mSocket.isConnected()) {
                    line = in.readLine();
                    Log.e("LINE", "[Current]- " + line);
                }
            } 
            catch (IOException e) {e.printStackTrace();}

        }
    }

person Spredzy    schedule 04.05.2010    source источник
comment
Вы когда-нибудь догадывались об этом? Я с той же проблемой.   -  person Gourneau    schedule 19.09.2013


Ответы (1)


Определите выходной поток как переменную-член, присоедините его к своему потоку и закройте этот поток только тогда, когда закончите...

В настоящее время вы открываете (и неявно закрываете) поток вывода внутри потока. Когда поток умирает, он закрывает этот выходной поток, что, в свою очередь, может убить сокет/соединение.

Если вы определяете поток вне потока, вы можете присоединить его к потоку и закрыть позже, например, когда службу попросят завершить работу.

person Brad Hein    schedule 04.05.2010