Stream
Last updated
Was this helpful?
Last updated
Was this helpful?
Stream์ Java8๋ถํฐ ์ถ๊ฐ๋ Collection์ ์ ์ฅ ์์๋ฅผ ํ๋์ฉ ์ฐธ์กฐํด์ Lambda์์ผ๋ก ์ฒ๋ฆฌํ ์ ์๋๋ก ํด์ฃผ๋ ๋ฐ๋ณต์์ด๋ค.
Stream์ Iterator์ ๋น์ทํ ์ญํ ์ ํ๋ ๋ฐ๋ณต์ ์ด์ง๋ง ๋ค์๊ณผ ๊ฐ์ ํน์ง์ ๊ฐ์ง๋ค.
๋๋ค์์ผ๋ก ์์ ์ฒ๋ฆฌ ์ฝ๋๋ฅผ ์ ๊ณตํ๋ค.
๋ด๋ถ ๋ฐ๋ณต์๋ฅผ ์ฌ์ฉํด ๋ณ๋ ฌ ์ฒ๋ฆฌ๊ฐ ์ฝ๋ค.
์ธ๋ถ ๋ฐ๋ณต์(external iterator)๋ ๊ฐ๋ฐ์๊ฐ ์ฝ๋๋ก ์ง์ Collection์ ์์๋ฅผ ๋ฐ๋ณตํด์ ๊ฐ์ ธ์ค๋ ํจํด์ ๋งํ๋ค. for๋ฌธ, Iterator๋ฅผ ์ด์ฉํ๋ whlie๋ฌธ ๋ชจ๋ ์ธ๋ถ ๋ฐ๋ณต์๋ฅผ ์ด์ฉํ๋ ๊ฒ์ด๋ค.
๋ด๋ถ ๋ฐ๋ณต์(internal iterator)๋ Collection ๋ด๋ถ์์ ์์๋ค์ ๋ฐ๋ณต์ํค๊ณ , ๊ฐ๋ฐ์๋ ์์๋น ์ฒ๋ฆฌํด์ผํ ์ฝ๋๋ง ์ ๊ณตํ๋ ํจํด์ ๋งํ๋ค. ๋ด๋ถ ๋ฐ๋ณต์๋ฅผ ์ฌ์ฉํด ๊ฐ๋ฐ์๋ ์์ ์ฒ๋ฆฌ ์ฝ๋์๋ง ์ง์คํ ์ ์์ผ๋ฉฐ, ๋ด๋ถ ๋ฐ๋ณต์๋ ๋ณ๋ ฌ ์์ ์ ํ ์ ์๋๋ก ๋์์ฃผ๊ธฐ ๋๋ฌธ์ ํจ์จ์ ์ผ๋ก ์์๋ฅผ ๋ฐ๋ณต์ํฌ ์ ์๋ค. ์คํธ๋ฆผ์ ์ด์ฉํ๋ฉด ์ฝ๋๋ ๊ฐ๊ฒฐํด์ง์ง๋ง, ์์์ ๋ณ๋ ฌ ์ฒ๋ฆฌ๊ฐ Collecton ๋ด๋ถ์์ ์ฒ๋ฆฌ๋๋๊ฒ์ด ๋ ์ข์ ํจ๊ณผ๋ฅผ ๊ฐ์ ธ์จ๋ค.
๋ค์๊ณผ ๊ฐ์ด ๋ณ๋ ฌ์ฒ๋ฆฌ ๋๋ ๊ฒ์ ํ์ธํ ์ ์๋ค.
์คํธ๋ฆผ์ ์ค๊ฐ ์ฒ๋ฆฌ์ ์ต์ข ์ฒ๋ฆฌ๋ฅผ ํ ์ ์๋ค.
์ค๊ฐ ์ฒ๋ฆฌ : ๋งคํ, ํํฐ๋ง, ์ ๋ ฌ
์ต์ข ์ฒ๋ฆฌ : ๋ฐ๋ณต, ์นด์ดํ , ํ๊ท , ์ดํฉ ๋ฑ์ ์ง๊ณ ์ฒ๋ฆฌ
BaseStream
์ธํฐํ์ด์ค์๋ ๋ชจ๋ ์คํธ๋ฆผ์์ ์ฌ์ฉํ ์ ์๋ ๊ณตํต ๋ฉ์๋๋ค์ด ์ ์ ๋์ด์์ผ๋ฉฐ, ์ง์ ์ฌ์ฉ๋์ง๋ ์๋๋ค.
Stream<T>
java.util.Collection.stream() java.util.Collection.parallelStream()
Collection
Stream<T> IntStream LongStream DoubleStream
Arrays.stream(T[]) Stream.of(T[]) Arrays.stream(int[]) IntStream.of(int[]) Arrays.stream(long[]) LongStream.of(long[]) Arrays.stream(double[]) DoubleStream.of(double[])
๋ฐฐ์ด
IntStream
IntStream.range(int, int) IntStream.rangeClosed(int, int)
int ๋ฒ์
LongStream
LongStream.range(long, long) LongStream.rangeClosed(long, long)
long ๋ฒ์
Stream<Path>
Files.find(Path, int, BiPredicate, FileVisitOption) Files.list(Path)
๋๋ ํ ๋ฆฌ
Stream<String>
Files.lines(Path, Charset) Files.list(Path)
ํ์ผ
DoubleStream IntStream LongStream
Random.doubles() Random.ints() Random.longs()
๋๋ค์
rangeClosed๋ ๋๋ฒ์งธ ์ธ์๋ฅผ ํฌํจํ๋ฉฐ, range๋ ๋๋ฒ์งธ ์ธ์๋ฅผ ํฌํจํ์ง ์๋๋ค.
๋๋์ ๋ฐ์ดํฐ๋ฅผ ๊ฐ๊ณตํด ์ถ์ํ๋ ๊ฒ์ ์ผ๋ฐ์ ์ผ๋ก Reduction
์ด๋ผ๊ณ ํ๋ค. ๋ฐ์ดํฐ์ ํฉ๊ณ, ํ๊ท ๊ฐ, ์นด์ดํ
, ์ต๋, ์ต์๊ฐ ๋ฑ์ด ๋ํ์ ์ธ ๋ฆฌ๋์
์ ๊ฒฐ๊ณผ๋ฌผ์ด๋ผ๊ณ ๋ณผ ์ ์๋ค. ์ด๋ ๊ฒฐ๊ณผ๋ฌผ๋ก ๋ฐ๋ก ์ง๊ณํ ์ ์๋ ๊ฒฝ์ฐ์๋ ์ค๊ฐ์ฒ๋ฆฌ(ํํฐ๋ง, ๋งคํ, ์ ๋ ฌ, ๊ทธ๋ฃนํ)์ด ํ์ํ๋ค.
ํ์ดํ๋ผ์ธ์ ์ฌ๋ฌ๊ฐ์ ์คํธ๋ฆผ์ด ์ฐ๊ฒฐ๋์ด ์๋ ๊ตฌ์กฐ๋ฅผ ๋งํ๋ฉฐ, ์ต์ข ์ฒ๋ฆฌ๋ฅผ ์ ์ธํ๊ณ ๋ ๋ชจ๋ ์ค๊ฐ ์ฒ๋ฆฌ ์คํธ๋ฆผ์ด๋ค.
์ค๊ฐ ์คํธ๋ฆผ์ด ์์ฑ๋ ๋ ์์๋ค์ด ๋ฐ๋ก ์ฒ๋ฆฌ๋๋ ๊ฒ์ด ์๋, ์ต์ข ์ฒ๋ฆฌ๊ฐ ์์๋๊ธฐ ์ ๊น์ง ์ค๊ฐ์ฒ๋ฆฌ๋ ์ง์ฐ(lazy)๋๋ฉฐ, ์ต์ข ์ฒ๋ฆฌ๊ฐ ์์๋๋ฉด ์ค๊ฐ ์คํธ๋ฆผ์์ ์ฒ๋ฆฌ๋ฅผ ์์ํ๋ค.
Java Platform SE8 ์์ ์ค๊ฐ์ฒ๋ฆฌ, ์ต์ ์ฒ๋ฆฌ ๊ด๋ จ ๋ฉ์๋ ์์๋ฅผ ์ดํด๋ณผ ์ ์๋ค.
๋ฆฌํดํ์
์ด ์คํธ๋ฆผ์ด๋ผ๋ฉด ์ค๊ฐ ์ฒ๋ฆฌ ๋ฉ์๋์ด๊ณ , ๊ธฐ๋ณธํ์
์ด๊ฑฐ๋ OptionalXXX
๋ผ๋ฉด ์ต์ข
์ฒ๋ฆฌ ๋ฉ์๋์ด๋ค.
Optional
ํด๋์ค๋ ์ ์ฅํ๋ ๊ฐ์ ํ์
๋ง ๋ค๋ฅผ ๋ฟ ์ ๊ณตํ๋ ๊ธฐ๋ฅ์ ๊ฑฐ์ ๋์ผํ๋ค. Optional
ํด๋์ค๋ ๋จ์ํ ์ง๊ณ ๊ฐ๋ง ์ ์ฅํ๋ ๊ฒ์ด ์๋๋ผ, ์ง๊ณ ๊ฐ์ด ์กด์ฌํ์ง ์์ ๊ฒฝ์ฐ ๋ํดํธ ๊ฐ์ ์ค์ ํ ์ ์๊ณ , ์ง๊ณ ๊ฐ์ ์ฒ๋ฆฌํ๋ Consumer
๋ ๋ฑ๋กํ ์ ์๋ค.
boolean
isPresent()
๊ฐ์ด ์ ์ฅ๋์ด ์๋์ง ์ฌ๋ถ
T double int long
orElse(T) orElse(double) orElse(int) orElse(long)
๊ฐ์ด ์ ์ฅ๋์ด ์์ง ์์ ๊ฒฝ์ฐ ๋ํดํธ ๊ฐ ์ง์
void
ifPresent(Consumer) ifPresent(DoubleConsumer) ifPresent(IntConsumer) ifPresent(LongConsumer)
๊ฐ์ด ์ ์ฅ๋์ด ์์ ๊ฒฝ์ฐ Consumer์์ ์ฒ๋ฆฌ
reduce๋ ์คํธ๋ฆผ์ ๋ชจ๋ ์์๋ค์ ํ๋์ ๊ฒฐ๊ณผ๋ก ํฉ์น๋ค.
Stream
Optional<T>
reduce(BinaryOperator<T> accumulator)
T
reduce(T identity, BinaryOperator<T> accumulator)
IntStream
OptionalInt
reduce(IntBinaryOperator op)
int
reduce(int identity, IntBinaryOperator op)
LongStream
OptionalLong
reduce(LongBinaryOperator op)
long
reduce(long identity, LongBinaryOperator op)
DoubleStream
OptionalDouble
reduce(DoubleBinaryOperator op)
double
reduce(double identity, DoubleBinaryOperator op)
ํ์๋ค์ ์ฑ์ ์ด์ ์ ๊ตฌํ๋ ์์์ด๋ค. ์ฌ๊ธฐ์ ์คํธ๋ฆผ์ ์์๊ฐ ์์ ๊ฒฝ์ฐ์ NoSuchElementException
์ด ๋ฐ์ํ๋ค.
identity(๋ํดํธ ๊ฐ)์ ์ฃผ์ด, ์คํธ๋ฆผ์ ์์๊ฐ ์์ ๊ฒฝ์ฐ์๋ 0์ ๋ฆฌํดํ๋ ์์์ด๋ค.
๋ค์์ 3๊ฐ์ ๋งค๊ฐ๋ณ์๋ฅผ ๋ฐ์ ์์์ด๋ค.
๋ค์๊ณผ ๊ฐ์ด ๋ณ๋ ฌ๋ก ์ฒ๋ฆฌ๋ฅผ ํ๋ฉด ์ด๋ป๊ฒ ์คํ๋๋์ง ํ์ธํ ์ ์๋ค.
collect ๋ฉ์๋๋ ํ์ํ ์์๋ง Collection
์ผ๋ก ๋ด์ ์ ์๊ณ , ์์๋ค์ ๊ทธ๋ฃนํํ ํ ์ง๊ณํ ์ ์๋ค.
R
collect(Collector<T,A,R> collertor)
Stream
๋งค๊ฐ๊ฐ์ธ Collector๋ ์ด๋ค ์์๋ฅผ ์ด๋ค Collection์ ์์งํ ๊ฒ์ธ์ง๋ฅผ ๊ฒฐ์ ํ๋ค. Collectors ๊ตฌํ ๊ฐ์ฒด๋ ์๋ Collectors ํด๋์ค์ ๋ค์ํ ์ ์ ๋ฉ์๋๋ฅผ ์ด์ฉํด์ ์ป์ ์ ์๋ค.
Collector<T, ?, List<T>>
toList()
T๋ฅผ List์ ์ ์ฅ
Collector<T, ?, Set<T>>
toSet()
T๋ฅผ Set์ ์ ์ฅ
Collector<T, ?, Collection<T>>
toCollection(Supplier<Collection<T>>)
T๋ฅผ Supplier๊ฐ ์ ๊ณตํ Collection์ ์ ์ฅ
Collertor<T, ?, Map<K,U>>
toMap( Function<T,K> keyMapper, Function<T,U> valueMapper)
T๋ฅผ K์ U๋ก ๋งคํํด K๋ฅผ ํค๋ก, U๋ฅผ ๊ฐ์ผ๋ก Map์ ์ ์ฅ
Collector<T, ?, ConcurrentMap<K,U>>
toConcurrentMap( Function<T,K> keyMapper, Function<T,U> valueMapper)
T๋ฅผ K์ U๋ก ๋งคํํด K๋ฅผ ํค๋ก, U๋ฅผ ๊ฐ์ผ๋ก ConcurrentMap์ ์ ์ฅ
๋ค์๊ณผ ๊ฐ์ด ๊ตฌํํ ์ ์๋ค.
collect๋ ๋จ์ํ ์์๋ฅผ ์์งํ๋ ๊ธฐ๋ฅ ์ธ์ Collection์ ์์๋ฅผ ๊ทธ๋ฃนํํด์ Map ๊ฐ์ฒด๋ฅผ ์์ฑํ๋ ๊ธฐ๋ฅ๋ ์ ๊ณตํ๋ค.
Collertor<T, ?, Map<K,List<T>>>
groupingBy(Function<T,K> classfier)
T๋ฅผ K๋ก ๋งคํํ๊ณ Kํค์ ์ ์ฅ๋ List์ T๋ฅผ ์ ์ฅํ Map ์์ฑ
Collertor<T, ?, ConcurrentMap<K,List<T>>>
groupingByConcurrent(Function<T,K> classfier)
Collertor<T, ?, Map<K, D>>
groupingBy( Function<T,K> classfier, Collector<T,A,D> collector)
T๋ฅผ K์ ๋งคํํ๊ณ Kํค์ ์ ์ฅ๋ D๊ฐ์ฒด์ T๋ฅผ ๋์ ํ Map ์์ฑ
Collertor<T, ?, ConcurrentMap<K, D>>
groupingByConcurrent( Function<T,K> classfier, Collector<T,A,D> collector)
Collertor<T, ?, Map<K, D>>
groupingBy( Function<T,K> classfier, Supplier<Map<K,D>> mapFactory, Collector<T,A,D> collector)
T๋ฅผ K๋ก ๋งคํํ๊ณ Supplier๊ฐ ์ ๊ณตํ๋ Map์์ Kํค์ ์ ์ฅ๋ D๊ฐ์ฒด์ T๋ฅผ ๋์
Collertor<T, ?, ConcurrentMap<K, D>>
groupingBy( Function<T,K> classfier, Supplier<ConcurrentMap<K,D>> mapFactory, Collector<T,A,D> collector)
๋ค์ ์์ ๋ ์ฑ์ ๋ณ๋ก ํด๋น Student List๋ฅผ ๊ตฌํ ์ ์๋ค.
๋ค์์ ์ฑ๋ณ๋ก ํ๊ท ์ ์๋ฅผ ์ ์ฅํ Map์ ๊ตฌํํ ์์ ์ด๋ค. ์์ ์์ ์ฒ๋ผ ๊ทธ๋ฃนํ ํ์ ๋งคํ์ด๋ ์ง๊ณ(ํ๊ท , ์นด์ดํ , ์ฐ๊ฒฐ, ์ต๋, ์ต์, ํฉ๊ณ)๋ฅผ ํ ์ ์๋ค.
๋ณ๋ ฌ ์ฒ๋ฆฌ๋ ๋ฉํฐ ์ฝ์ด CPU ํ๊ฒฝ์์ ํ๋์ ์์ ์ ๋ถํ ํด์ ๊ฐ๊ฐ์ ์ฝ์ด๊ฐ ๋ณ๋ ฌ์ ์ผ๋ก ์ฒ๋ฆฌํ๋ ๊ฒ์ ๋งํ๋ฉฐ, ์์ ์ฒ๋ฆฌ ์๊ฐ์ ์ค์ด๊ธฐ ์ํด ์ฌ์ฉํ๋ค. Java8๋ถํฐ ๋ณ๋ ฌ ์คํธ๋ฆผ์ ์ ๊ณตํ๊ณ ์๋ค.
๋ฉํฐ ์ฐ๋ ๋๋ ๋์์ฑ(Concurrency)์ ๋ณ๋ ฌ์ฑ(Parallelism)์ผ๋ก ์คํ๋๊ณ ์๋ค.
๋์์ฑ : ๋ฉํฐ ์ค๋ ๋๊ฐ ๋ฒ๊ฐ์๊ฐ๋ฉฐ ์คํํ๋ ์ฑ์ง
๋ณ๋ ฌ์ฑ : ๋ฉํฐ ์ฝ์ด๋ฅผ ์ด์ฉํด ๋์์ ์คํํ๋ ์ฑ์ง
๋ฐ์ดํฐ ๋ณ๋ ฌ์ฑ : ์ ์ฒด ๋ฐ์ดํฐ๋ฅผ ์ชผ๊ฐ์ด ์๋ธ ๋ฐ์ดํฐ๋ค๋ก ๋ง๋ค๊ณ ์ด ๋ฐ์ดํฐ๋ค์ ๋ณ๋ ฌ ์ฒ๋ฆฌํด ์์ ์ ๋นจ๋ฆฌ ๋๋ด๋ ๊ฒ(parallelStream)
์์ ๋ณ๋ ฌ์ฑ : ์๋ก ๋ค๋ฅธ ์์ ์ ๋ณ๋ ฌ ์ฒ๋ฆฌํ๋ ๊ฒ(Web Server : ๊ฐ๊ฐ ๋ธ๋ผ์ฐ์ ์์ ์์ฒญํ ๋ด์ฉ์ ๊ฐ๋ณ ์ค๋ ๋์์ ๋ณ๋ ฌ๋ก ์ฒ๋ฆฌ)
์ฑ๊ธ ์ฝ์ด CPU๋ฅผ ์ด์ฉํ ๋ฉํฐ ์์ ์ ๋ณ๋ ฌ์ ์ผ๋ก ์คํ๋๋ ๊ฒ์ฒ๋ผ ๋ณด์ด์ง๋ง, ๋ฒ๊ฐ์๊ฐ๋ฉฐ ์คํํ๋ ๋์์ฑ ์์ ์ด๋ค.