【问题标题】:How to implement generic Function method parameters?如何实现泛型 Function 方法参数?
【发布时间】:2019-04-12 10:00:16
【问题描述】:

目前我必须根据要传递给方法的Function 的类型定义不同的方法,例如:

addCustomParameter(orderLinePrefix + "quantity=", concatenateLong(orderLines, OrderPart::getQuantity));
addCustomParameter(orderLinePrefix + "surcharge=", concatenateDouble(orderLines, OrderPart::getSurcharge));
addCustomParameter(orderLinePrefix + "dropship=", concatenateBoolean(orderLines, OrderPart::isDropship));

方法如下所示:

@Nonnull
    public <T> String concatenateBoolean(@Nonnull final Collection<T> items, @Nonnull final Function<T, Boolean> mapper)
    {
        return items.stream()
                .map(mapper)
                .map(String::valueOf)
                .collect(joining(","));
    }

    @Nonnull
    public <T> String concatenateLong(@Nonnull final Collection<T> items, @Nonnull final Function<T, Long> mapper)
    {
        return items.stream()
                .map(mapper)
                .map(String::valueOf)
                .collect(joining(","));
    }

    @Nonnull
    public <T> String concatenateDouble(@Nonnull final Collection<T> items, @Nonnull final Function<T, Double> mapper)
    {
        return items.stream()
                .map(mapper)
                .map(String::valueOf)
                .collect(joining(","));
    }

如何将上述 3 个方法重构为一个可以接受任何类型并返回 String 的方法?

【问题讨论】:

标签: java function generics java-8 java-stream


【解决方案1】:

为映射器使用通配符返回类型:

@Nonnull
public <T> String concatenateAny(@Nonnull final Collection<T> items, @Nonnull final Function<? super T, ?> mapper)
{
    return items.stream()
            .map(mapper)
            .map(String::valueOf)
            .collect(joining(","));
}

【讨论】:

  • 请注意,由于 OP 的实际用例为每次调用使用方法引用参数,Function&lt;T, Object&gt; mapper 参数也可以工作。但是使用通配符可以提高现有 Function 实例的灵活性。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-06-28
  • 2018-09-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多