== Why is this an issue? Stream operations are divided into intermediate and terminal operations, and are combined to form stream pipelines. After the terminal operation is performed, the stream pipeline is considered consumed, and cannot be used again. Such a reuse will yield unexpected results. === Noncompliant code example [source,java] ---- Stream pipeline = widgets.stream().filter(b -> b.getColor() == RED); int sum1 = pipeline.sum(); int sum2 = pipeline.mapToInt(b -> b.getWeight()).sum(); // Noncompliant ---- == Resources https://docs.oracle.com/javase/8/docs/api/java/util/stream/package-summary.html#StreamOps[Stream Operations] ifdef::env-github,rspecator-view[] ''' == Implementation Specification (visible only on this page) === Message Refactor this code so that this consumed stream pipeline is not reused. === Highlighting Primary: Operation invoked on consumed stream Secondary: The previous terminal operation on that stream endif::env-github,rspecator-view[]