Вопрос

В моем приложении Android я пытаюсь подключиться к порту на локальном сервере, чтобы получить несколько пакетов. Я закрыл кодирую в некоторых попытках, но со следующим кодом:

address = "192.168.175.82";
public void run() {
    try {
  smtpSocket = new Socket(address, 60001);

        os = new DataOutputStream(smtpSocket.getOutputStream());
        is = new DataInputStream(smtpSocket.getInputStream());
    } catch (UnknownHostException e) {
        System.err.println("Don't know about host: " + address);
        run();
    } catch (IOException e) {
        System.err.println("Couldn't get I/O for the connection to: " + address);
        run();
    } catch (Exception e) {
     System.out.println("retry");
     run();
    }

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

01-20 22:21:32.526: ERROR/AndroidRuntime(5678): java.lang.StackOverflowError
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.util.Hashtable.get(Hashtable.java:282)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.util.Properties.getProperty(Properties.java:177)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.lang.System.getProperty(System.java:440)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.lang.System.getProperty(System.java:412)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.lang.Boolean.getBoolean(Boolean.java:174)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at org.apache.harmony.luni.net.NetUtil$Action.run(NetUtil.java:89)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at org.apache.harmony.luni.net.NetUtil$Action.run(NetUtil.java:80)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.security.AccessController.doPrivilegedImpl(AccessController.java:264)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.security.AccessController.doPrivileged(AccessController.java:84)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at org.apache.harmony.luni.net.NetUtil.preferIPv6Addresses(NetUtil.java:51)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at org.apache.harmony.luni.net.PlainSocketImpl.bind(PlainSocketImpl.java:190)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.net.Socket.startupSocket(Socket.java:777)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.net.Socket.tryAllAddresses(Socket.java:192)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.net.Socket.<init>(Socket.java:256)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at java.net.Socket.<init>(Socket.java:220)
01-20 22:21:32.526: ERROR/AndroidRuntime(5678):     at com.example.sockets.ReadSocket.run(ReadSocket.java:83)

Может ли кто-нибудь, пожалуйста, укажите меня в правильном направлении, как сделать это на работу? Возможно, я должен проверить соединение первым как-то (если так, пожалуйста, скажите, как?) Спасибо

Крис

Это было полезно?

Решение

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

  public void run() {
     boolean connected = false;  
     while(!connected)
     {
     try {
      smtpSocket = new Socket(address, 60001);

            os = new DataOutputStream(smtpSocket.getOutputStream());
            is = new DataInputStream(smtpSocket.getInputStream());


      connected = true;
    } catch (UnknownHostException e) {
        System.err.println("Don't know about host: " + address);

    } catch (IOException e) {
        System.err.println("Couldn't get I/O for the connection to: " + address);

        } catch (Exception e) {
         System.out.println("retry");

        }
        if (!connected)
            Thread.sleep(1000)
      }
    }

Другие советы

Можешь попробовать isConnected() а также isBound() На вашем сокете, чтобы проверить, вы подключены или не перед попыткой получения ввода.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top