#BAEL-18410 add code sample for reduce with complex objects
This commit is contained in:
parent
1ff66911d3
commit
d6bcc02f09
|
@ -0,0 +1,39 @@
|
||||||
|
package com.baeldung.streamreduce.entities;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class Rating {
|
||||||
|
|
||||||
|
double points;
|
||||||
|
List<Review> reviews = new ArrayList<>();
|
||||||
|
|
||||||
|
public Rating() {}
|
||||||
|
|
||||||
|
public void add(Review review) {
|
||||||
|
reviews.add(review);
|
||||||
|
computeRating();
|
||||||
|
}
|
||||||
|
|
||||||
|
private double computeRating() {
|
||||||
|
double totalPoints = reviews.stream().map(Review::getPoints).reduce(0, Integer::sum);
|
||||||
|
this.points = totalPoints / reviews.size();
|
||||||
|
return this.points;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Rating average(Rating r1, Rating r2) {
|
||||||
|
Rating combined = new Rating();
|
||||||
|
combined.reviews = new ArrayList<>(r1.reviews);
|
||||||
|
combined.reviews.addAll(r2.reviews);
|
||||||
|
combined.computeRating();
|
||||||
|
return combined;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPoints() {
|
||||||
|
return points;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Review> getReviews() {
|
||||||
|
return reviews;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,28 @@
|
||||||
|
package com.baeldung.streamreduce.entities;
|
||||||
|
|
||||||
|
public class Review {
|
||||||
|
|
||||||
|
int points;
|
||||||
|
String review;
|
||||||
|
|
||||||
|
public Review(int points, String review) {
|
||||||
|
this.points = points;
|
||||||
|
this.review = review;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getPoints() {
|
||||||
|
return points;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPoints(int points) {
|
||||||
|
this.points = points;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getReview() {
|
||||||
|
return review;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setReview(String review) {
|
||||||
|
this.review = review;
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,6 +4,7 @@ public class User {
|
||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
private final int age;
|
private final int age;
|
||||||
|
private final Rating rating = new Rating();
|
||||||
|
|
||||||
public User(String name, int age) {
|
public User(String name, int age) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
@ -18,6 +19,10 @@ public class User {
|
||||||
return age;
|
return age;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Rating getRating() {
|
||||||
|
return rating;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "User{" + "name=" + name + ", age=" + age + '}';
|
return "User{" + "name=" + name + ", age=" + age + '}';
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package com.baeldung.streamreduce.tests;
|
package com.baeldung.streamreduce.tests;
|
||||||
|
|
||||||
|
import com.baeldung.streamreduce.entities.Rating;
|
||||||
|
import com.baeldung.streamreduce.entities.Review;
|
||||||
import com.baeldung.streamreduce.entities.User;
|
import com.baeldung.streamreduce.entities.User;
|
||||||
import com.baeldung.streamreduce.utilities.NumberUtils;
|
import com.baeldung.streamreduce.utilities.NumberUtils;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -64,6 +66,31 @@ public class StreamReduceManualTest {
|
||||||
assertThat(result).isEqualTo(65);
|
assertThat(result).isEqualTo(65);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUserList_whenReduceWithGreaterAgeAccumulator_thenFindsOldest() {
|
||||||
|
List<User> users = Arrays.asList(new User("John", 30), new User("Alex", 40), new User("Julie", 35));
|
||||||
|
|
||||||
|
User oldest = users.stream().reduce(users.get(0), (user1, user2) -> user1.getAge() >= user2.getAge() ? user1 : user2);
|
||||||
|
|
||||||
|
assertThat(oldest).isEqualTo(users.get(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUserListWithRatings_whenReduceWithGreaterAgeAccumulator_thenFindsOldest() {
|
||||||
|
User john = new User("John", 30);
|
||||||
|
john.getRating().add(new Review(5, ""));
|
||||||
|
john.getRating().add(new Review(3, "not bad"));
|
||||||
|
User julie = new User("Julie", 35);
|
||||||
|
john.getRating().add(new Review(4, "great!"));
|
||||||
|
john.getRating().add(new Review(2, "terrible experience"));
|
||||||
|
john.getRating().add(new Review(4, ""));
|
||||||
|
List<User> users = Arrays.asList(john, julie);
|
||||||
|
|
||||||
|
Rating averageRating = users.stream().reduce(new Rating(), (rating, user) -> Rating.average(rating, user.getRating()), Rating::average);
|
||||||
|
|
||||||
|
assertThat(averageRating.getPoints()).isEqualTo(3.6);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenStringList_whenReduceWithParallelStream_thenCorrect() {
|
public void givenStringList_whenReduceWithParallelStream_thenCorrect() {
|
||||||
List<String> letters = Arrays.asList("a", "b", "c", "d", "e");
|
List<String> letters = Arrays.asList("a", "b", "c", "d", "e");
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
|
<relativePath>../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
|
Loading…
Reference in New Issue