package book.example.threading.executor; import book.example.common.searching.AuctionDescription; import book.example.common.searching.AuctionHouse; import book.example.common.searching.async.AuctionSearchConsumer; import java.util.List; import java.util.Set; import java.util.concurrent.Executor; /** * No synchronisation yet... let's get the functionality sorted */ public class AuctionSearch_v2 { private final Executor executor; private final List<AuctionHouse> auctionHouses; private final AuctionSearchConsumer consumer; private int runningSearchCount = 0; public AuctionSearch_v2(Executor executor, List<AuctionHouse> auctionHouses, AuctionSearchConsumer consumer) { this.executor = executor; this.auctionHouses = auctionHouses; this.consumer = consumer; } public void search(Set<String> keywords) { for (AuctionHouse auctionHouse : auctionHouses) { startSearching(auctionHouse, keywords); } } private void startSearching(final AuctionHouse auctionHouse, final Set<String> keywords) { runningSearchCount++; executor.execute(new Runnable() { public void run() { search(auctionHouse, keywords); } }); } private void search(AuctionHouse auctionHouse, Set<String> keywords) { // BUG1: THIS IS CORRECT List<AuctionDescription> found = auctionHouse.findAuctions(keywords); if (!found.isEmpty()) { consumer.auctionSearchFound(found); } // BUG1: THIS IS INCORRECT //consumer.auctionSearchFound(auctionHouse.findAuctions(keywords)); runningSearchCount--; if (runningSearchCount == 0) { consumer.auctionSearchFinished(); } } }