Я реализовал свой собственный сервис для Android следующим образом
public class MyService extends Service {
private static final String TAG = "MyService";
private Server mServer;
private LocalServerSocket server;
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onCreate() {
Log.d(TAG, "onCreate");
mServer = new Server();
mServer.start();
}
@Override
public void onDestroy() {
Log.d(TAG, "onDestroy");
if(server != null){
try {
server.close();
} catch (IOException e) {
Log.d(TAG, "exception in server close");
e.printStackTrace();
}
}
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.d(TAG, "onStart");
return START_STICKY;
}
class Server extends Thread {
@Override
public void run() {
try {
server = new LocalServerSocket("my.socket");
while (true) {
LocalSocket receiver;
try{
receiver = server.accept();
}catch(SocketException e){
Log.d(TAG, "SocketException");
break;
}
catch(IOException e){
Log.d(TAG, "IOException");
break;
}
if (receiver != null) {
Log.d(TAG, "Got Data in receiver");
}
receiver.close();
}
} catch (IOException e) {
Log.d(TAG, "one more");
e.printStackTrace();
}
}
}
}
Проблема, с которой я сталкиваюсь, заключается в том, что если мой LocalServerSocket блокируется в accept (), то вызывается метод server.close () в OnDestroy.() не будет генерировать исключение SocketException.Следовательно, в следующий раз, когда я запускаю сервис, я получаю «адрес, который уже используется, исключение».Если вместо LocalServerSocket я использую java.net.Socket, то получаю требуемое поведение.Я хотел бы знать, почему LocalServerSocket ведет себя не так, как Java Sockets.В моем случае, как мне выйти из цикла while.