I believe I can do next using one stream operation on listOfPricedObjects:
List myList = new ArrayList();
myList = listOfPricedObjects.stream().map(PricedObject::getPrice).collect(Collectors.toList());
BigDecimal sum = listOfPricedObjects.stream().map(PricedObject::getPrice).reduce(BigDecimal.ZERO, BigDecimal::add)
How I can fill myList with prices and calculate sum of prices using stream one time?
Thanks
UPD: As the result I need myList filled with prices and sum variable with sum. But not with usding stream() twice for that.
解决方案
You can use peek and add to a new list while applying the reduction
List newList = new ArrayList<>();
BigDecimal sum = list.stream()
.map(PricedObject::getPrice)
.peek(newList::add)
.reduce(BigDecimal.ZERO, BigDecimal::add);
Please look at Tunaki answer if you interested in using a parallelStream with a non concurrent collection which makes sense since sum as an embarrassingly parallel task.