Цепочка «instanceof» для сборки объекта - PullRequest
3 голосов
/ 23 ноября 2011

У меня следующий код:

public class BaseGroup {

    private Group1 group1;
    private Group2 group2;
    private Group3 group3;

    public void setGroup (IGroup group) {

        if(group instanceof Group1) {
            setGroup1((Group1) group);
        } else if(group instanceof Group2) {
            setGroup2((Group2) group);
        } else {
            setGroup3((Group3) group);
        }
    }

    public Group1 getGroup1() {
        return group1;
    }

    public void setGroup1(Group1 group1) {
        this.group1 = group1;
    }

    public Group2 getGroup2() {
        return group2;
    }

    public void setGroup2(Group2 group1) {
        this.group2 = group2;
    }

    public Group3 getGroup3() {
        return group3;
    }

    public void setGroup3(Group3 group1) {
        this.group3 = group3;
    }

}   

И класс BaseGroup используется таким образом.

BaseGroup baseGroup = New BaseGroup();
basegroup.setGroup(group);

Мой вопрос касается этой цепочки «instanceof», вызывающей соответствующие сеттеры для сборки объекта BaseGroup. Какой лучший подход для этого?

Ответы [ 7 ]

5 голосов
/ 23 ноября 2011

Вы можете добавить метод к

interface IGroup {
    public void addToGroup(BaseGroup bg);
}

class Group1 implements IGroup {
    public void addToGroup(BaseGroup bg) { bg.setGroup1(this); }
}
// etc for Group2 and 3.


IGroup group;
BaseGroup bg;
group.addToGroup(bg);
1 голос
/ 23 ноября 2011

Полиморфизм (в частности, перегрузка метода) может действительно работать здесь.

public void setGroup(Group1 group) {
  this.group1 = group;
}
public void setGroup(Group2 group) {
  this.group2 = group;
}
public void setGroup(Group3 group) {
  this.group3 = group;
}

Java автоматически выберет соответствующий метод.

1 голос
/ 23 ноября 2011

Зависит от того, как вы используете group1, 'group2', 'group3'.Нечто подобное может сработать:

class BaseGroup {
    private final List<Group> groups = new ArrayList<Group>();

    public void addGroup(Group group) {
         groups.add(group);
    }
}
0 голосов
/ 23 ноября 2011
interface Group{}
class Group1 implements Group{}
class Group2 implements Group{}
class Group3 implements Group{}


public class BaseGroup {

    private Map<Class<Group>, <Group>>  groups = new HashMap<Class<Group>, <Group>>();

    public void setGroup (Group group) {
        groups.put(group.getClass(), group);
    }

}
0 голосов
/ 23 ноября 2011

Лучшее, чего следует избегать, это шаблон посетителей, пожалуйста, используйте его.

0 голосов
/ 23 ноября 2011
public class BaseGroup {

private Map<Class<IGroup>, IGroup> groupsFactoryByClass;

public void setGroup (IGroup group) {
    IGroup oldGroup = groupsFactoryByClass.put(group.getClass());
    if (oldGroup != null)
        throw new IllegalArgumentException("Group with class " + group.getClass().getName() + " already set");
}

public <T implements IGroup> getGroup(Class<T> klazz) {
    return groupsFactoryByClass.get(klazz);
}
}
0 голосов
/ 23 ноября 2011

Другая альтернатива - использование Reflection.

...