Как избежать непроверенных предупреждений о приведении с помощью Java Generics - PullRequest
16 голосов
/ 29 февраля 2012

Каким-то образом мой старый вопрос был закрыт, поэтому я открываю новый:

Я использую Java Generics для реализации универсальной двунаправленной Hash Map из SQL-запроса. Он должен иметь возможность отображать любую комбинацию пар String, Integer туда и обратно. Это следует использовать так:

String sql = "SELECT string_val, int_val FROM map_table";
PickMap<String, Integer> pm1 = new PickMap<String, Integer>(sql);

String key1 = "seven";
Integer value1 = pm1.getLeft2Right(key1);

Integer key2 = 7;
String value2 = pm1.getRightToLeft(key2);

Конечно, должна быть возможность создать личку (Integer, Integer) и так далее ...

Моя реализация Pick Map выглядит следующим образом (без геттера ...):

public class PickMap<L, R> {

    private final HashMap<L, R> left2Right = new HashMap<L, R>();
    private final HashMap<R, L> right2Left = new HashMap<R, L>();

    public PickMap(String sql) throws OException {
        DTable d = new DTable(sql);
        int colTypeL = d.t.getColType(1);
        int colTypeR = d.t.getColType(2);
        Extractor<L> extLeft  = (Extractor<L>) getInstance(colTypeL);
        Extractor<R> extRight = (Extractor<R>) getInstance(colTypeR);    
        int numRows = d.t.getNumRows();
        for(int i=1;i<=numRows;i++) {
            L leftVal = extLeft.extract(d, i);
            R rightVal = extRight.extract(d, i);
            this.left2Right.put(leftVal, rightVal);
            this.right2Left.put(rightVal, leftVal);
        }
    }

    private Extractor<?> getInstance(int type) {
        if(type == 1)
            return new IntExtractor();
        else
            return new StringExtractor();
    }
}

interface Extractor<E> {
    E extract(DTable source, int row);
}

class IntExtractor implements Extractor<Integer> {

    @Override
    public Integer extract(DTable source, int row) {
        int value = 5;
        return new Integer(value);
    }
}

class StringExtractor implements Extractor<String> {

    @Override
    public String extract(DTable source, int row) {
        String retVal = "hello";
        return retVal;
    }
}

У меня нет ошибок компилятора, и я почти уверен, что так оно и будет. НО я получаю непроверенные предупреждения о приведении методов "getInstance", где я разыгрываю Extractor (E) в Extractor (L) ...

Как правильно кастовать? Или чего мне не хватает? Или я должен просто подавить эти предупреждения?

Ответы [ 3 ]

28 голосов
/ 29 февраля 2012

Вы получаете предупреждения, потому что то, что вы делаете, не может быть доказано в безопасности.Вы предполагаете , что getInstance(colTypeL) вернет Extractor<L> - но это невозможно проверить ни во время компиляции, ни во время выполнения.

Вы можете использовать @SuppressWarnings("unchecked") какупомянутые другими, но я бы попытался несколько переосмыслить дизайн.

7 голосов
/ 29 февраля 2012

Вы можете использовать следующую аннотацию, чтобы компилятор не выводил эти предупреждения:

@SuppressWarnings("unchecked")

См. Этот связанный вопрос , касающийся той же проблемы.Ответ там объяснит все, что вам нужно знать.

1 голос
/ 17 мая 2019

Если вы используете Spring Framework, вы можете использовать CastUtils:

import static org.springframework.data.util.CastUtils.cast;
obj.setString(cast(someObject));
String bob = cast(someObject);
...