我知道这是一个菜鸟问题,但在其他任何地方都找不到简单答案。问题是:我需要编写一个返回SortedMap的方法,因此树图应该可以正常工作。
我有一个HashMap< String, Skill>Skill类同时具有getNamegetNumApplicants方法,我需要返回SortedMap<String, Long>,以技能名称为键,申请人数量为值。我站在这里:

private Map<String,Skill> skillMap = new HashMap<>();

public SortedMap<String, Long> skill_nApplicants() {

    return skillMap.values().stream().collect(...);
}

这是技能课
public class Skill {

    private String name;
    private List <Position> reqPosition = new ArrayList<>();
    private Long numApplicants;

    public void plusOneApplicant() {
        this.numApplicants++;
    }

    public Long getNumApplicants() {
        return numApplicants;
    }
    public Skill(String name) {
        super();
        this.name = name;
        this.numApplicants = 0L;
    }
    public String getName() {
        return name;
        }

    public List<Position> getPositions() {
        return reqPosition;
        }
    public void addReqPosition(Position p) {
        this.reqPosition.add(p);
        return;
    }
}

我知道这应该很容易,我很难理解所有这一切。

最佳答案

不要先将数据收集到HashMap,然后再转换为TreeMap。通过使用重载的 TreeMap 方法将数据直接收集到toMap(keyMapper, valueMapper, mergeFunction, mapSupplier)中,该方法允许您指定要创建的Map(第4个参数)。

public SortedMap<String, Long> skill_nApplicants() {
    return skillMap.values().stream().collect(Collectors.toMap(
            Skill::getName,
            Skill::getNumApplicants,
            Math::addExact, // only called if duplicate names can occur
            TreeMap::new
    ));
}

07-26 03:51