Скажем, у меня есть несколько больших (несколько миллионов элементов или около того) список строк. Это хорошая идея запустить что-то вроде этого:
val updatedList = myList.par.map(someAction).toList
Или лучше было бы сгруппировать список перед запуском ...par.map(
, например:
val numberOfCores = Runtime.getRuntime.availableProcessors
val updatedList =
myList.grouped(numberOfCores).toList.par.map(_.map(someAction)).toList.flatten
UPDATE:
Учитывая, что someAction
довольно дорого (по сравнению с grouped
, toList
и т.д.)