Спасибо, @Waldheinz - слился.

я есть класс Server и таймер внутри него, который предназначен для очистки мертвых клиентов (клиентов, которые потерпели крах). Я следовал приведенному ниже примеру, блокируя коллекцию, когда Timer перебирает пользователей, но я все еще получаю это исключение (после сбоя подключенного клиента).

http://www.javaperformancetuning.com/articles/fastfail2.shtml

List<User> users;
List<User> connectedUsers;
ConcurrentMap<User, IClient> clients;

...

users = Collections.synchronizedList(new ArrayList<User>());
connectedUsers = new ArrayList<User>();
clients = new ConcurrentHashMap<User, IClient>();
timer = new Timer();
timer.schedule(new ClearDeadClients(), 5000, 5000);

...

class ClearDeadClients extends TimerTask {
    public void run() {
        synchronized (users) {
            Iterator<User> it = users.iterator();
            while (it.hasNext()) {
                User user = it.next(); // Throws exception
                if (!connectedUsers.contains(user)) {
                    users.remove(user);
                    clients.remove(user);
                }
            }
        }       

        connectedUsers.clear();
    }
}

Ответы на вопрос(2)

Ваш ответ на вопрос