Padrão de Design de Estratégia, Genéricos e TipoSegurança

Eu quero criar o seguinte padrão de estratégia combinado com o Factory, mas eu quero que ele seja seguro. Eu fiz o seguinte até agora:

public interface Parser<T> {

    public Collection<T> parse(ResultSet resultSet);

}


public class AParser implements Parser<String> {

    @Override
    public Collection<String> parse(ResultSet resultSet) {
             //perform parsing, get collection
        Collection<String> cl = performParsing(resultSet); //local private method
        return cl;
    }
}

public class ParserFactory {

    public enum ParserType {
        APARSER
    }


    public static <T> Parser<T> createParser(ParserType parserType) {


        Parser<?> parser = null;
        switch (parserType) {
        case APARSER:
            parser = new AParser();
            break;
        }
            //unchecked cast happens here
        return (Parser<T>) parser;
    }
}


public class Context {

      public <T> Collection<T> getResults(String query, ParserType parserType) {
          ResultSet resultSet() = getResultSet(query); //local private method
          Parser p = ParserFactory.createParser(parserType);
          Collection<T> results = p.parse(resultSet)
      }

}

Em geral, seja o que for que eu tente, em algum lugar eu vou ter um elenco não verificado. Alguém tem uma ideia de como posso refatorar o código para ser seguro?

Verificando o Java efetivo eu também tropecei nesse padrão:

public final class ParserFactory {

    private ParserFactory() {

    }

    private static class AParser implements Parser<String> {
        @Override
        public Collection<String> parse(ResultSet resultSet) {
            //...
            return new ArrayList<>();
        }
    }

    public static final Parser<String> APARSER = new AParser();

}

Então agora eu posso usar como Ingo sugeriu

public <T> Collection<T> getResults(String query, Parser<T> p)

Como

getResults("query", ParserFactory.APARSER);

Ou isso seria melhor com enums?

questionAnswers(3)

yourAnswerToTheQuestion