java.util.ConcurrentModificationException en ArrayList

Tengo una clase de servidor y un temporizador en su interior que se supone que elimina a los clientes muertos (clientes que se bloquearon). Seguí el ejemplo a continuación bloqueando la colección cuando el temporizador itera sobre los usuarios, pero aún obtengo esta excepción (después de bloquear un cliente conectado).

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

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();
    }
}

Respuestas a la pregunta(2)

Su respuesta a la pregunta