У меня возникла проблема со следующим примером кода, который показывает противоречивое поведение для EventQueue:
public static void main( String[] args ) throws InvocationTargetException, InterruptedException {
final long[] id1 = new long[ 1 ];
final long[] id2 = new long[ 1 ];
EventQueue.invokeAndWait( new Runnable() {
@Override public void run() {
id1[ 0 ] = Thread.currentThread().getId();
}
} );
Thread.sleep( 5000 );
EventQueue.invokeAndWait( new Runnable() {
@Override public void run() {
id2[ 0 ] = Thread.currentThread().getId();
}
} );
System.out.println( "id1 = " + id1[0] );
System.out.println( "id2 = " + id2[0] );
if(id1[0]!=id2[0]){
System.out.println("These ID's don't match, even though they were retrieved from the same thread.");
}
}
По сути, он получает идентификатор потока очереди событий, ждет 5 секунд, а затем снова получает идентификатор.
По какой-то причине идентификаторы не совпадают. Судя по всему, EventQueue была уничтожена и создана заново. Это нормальное поведение? Это где-то задокументировано? Это ошибка? Даже если это был другой экземпляр, разве у него не должен быть тот же идентификатор?
Если я не выполню Thread.sleep
, идентификаторы совпадут.
Мой другой вопрос: как я могу обойти это? Я использую объект, к которому можно получить доступ только в потоке создания. Если это очередь событий (что не обязательно должно быть), я должен иметь возможность проверить, является ли она все еще очередью событий.