我正在学习Stream,在一次这样的练习中,我试图通过以下代码加入2个不同类型的String和Integer流:
Stream<String> fruitStream = Stream.of("Apple", "Mango", "Muskmalon", "Guvava");
Stream<Integer> vegetablesStream = Stream.of(1, 2, 3, 4);
Stream<String> mixStream = Stream.concat(fruitStream, vegetablesStream.map(i -> i.toString()));
mixStream.forEach(System.out :: println);
它工作正常,给了我想要的结果。
然后我尝试使用方法参考:
Stream<String> mixStream = Stream.concat(fruitStream, vegetablesStream.map(Integer :: toString));
它开始抛出错误:
Wrong 1st argument type. Found: 'java.util.stream.Stream<java.lang.String>', required: 'java.util.stream.Stream<? extends T>'
concat (java.util.stream.Stream<? extends T>, java.util.stream.Stream<? extends T>) in Stream cannot be applied to (java.util.stream.Stream<java.lang.String>, java.util.stream.Stream<R>)
reason: No compile-time declaration for the method reference is found
当我用String:: ValueOf替换我的方法引用时,它工作正常:
Stream<String> mixStream = Stream.concat(fruitStream, vegetablesStream.map(String :: valueOf));
我无法理解为什么整数:: toString失败,但字符串:: value eOf通过?
错误消息应该是模糊的方法引用:Integer类型的toString()和toString(int)都符合
的条件。发生这种情况是因为toString
和toString(int)
都有资格在此处使用。
可能两者都有:
.map(i -> i.toString(i))
.map(i -> i.toString())
它工作得很好,因为String::value eOf
没有这样的重载方法,因此编译器对此很好。