From 95242e8cf92c0853fb995bd9768a9307958ccbd9 Mon Sep 17 00:00:00 2001 From: vraskulin Date: Mon, 19 Dec 2016 15:58:08 +0300 Subject: [PATCH] Concurrency perfomance boost Checking if image exist or not now parallel. It took 35-39 seconds to perform, now it takes 13-16 seconds. Planning to make all class method concurrent and reduce client loading time even more. --- .../plugins/card/images/DownloadPictures.java | 32 ++++++++----------- 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/Mage.Client/src/main/java/org/mage/plugins/card/images/DownloadPictures.java b/Mage.Client/src/main/java/org/mage/plugins/card/images/DownloadPictures.java index efb627fefc..e086d32cf4 100644 --- a/Mage.Client/src/main/java/org/mage/plugins/card/images/DownloadPictures.java +++ b/Mage.Client/src/main/java/org/mage/plugins/card/images/DownloadPictures.java @@ -19,11 +19,7 @@ import java.net.Proxy; import java.net.URL; import java.net.URLConnection; import java.nio.file.AccessDeniedException; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Set; +import java.util.*; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import javax.imageio.IIOImage; @@ -78,8 +74,8 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab private final JButton closeButton; private JButton startDownloadButton; private int cardIndex; - private ArrayList cards; - private ArrayList type2cards; + private List cards; + private List type2cards; private final JComboBox jComboBox1; private final JLabel jLabel1; private static boolean offlineMode = false; @@ -96,7 +92,7 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab } public static void startDownload(JFrame frame, List allCards) { - ArrayList cards = getNeededCards(allCards); + List cards = getNeededCards(allCards); /* * if (cards == null || cards.isEmpty()) { @@ -127,7 +123,7 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab this.cancel = cancel; } - public DownloadPictures(ArrayList cards) { + public DownloadPictures(List cards) { this.cards = cards; bar = new JProgressBar(this); @@ -254,7 +250,7 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab } private void updateCardsToDownload() { - ArrayList cardsToDownload = cards; + List cardsToDownload = cards; if (type2cardsOnly()) { selectType2andTokenCardsIfNotYetDone(); cardsToDownload = type2cards; @@ -288,9 +284,9 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab return className.substring(className.lastIndexOf('.') + 1); } - private static ArrayList getNeededCards(List allCards) { + private static List getNeededCards(List allCards) { - ArrayList cardsToDownload = new ArrayList<>(); + List cardsToDownload = Collections.synchronizedList(new ArrayList<>()); /** * read all card names and urls @@ -360,18 +356,18 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab } int numberTokenImages = allCardsUrls.size() - numberCardImages; - TFile file; + /** * check to see which cards we already have */ - for (CardDownloadData card : allCardsUrls) { - file = new TFile(CardImageUtils.generateImagePath(card)); + allCardsUrls.parallelStream().forEach(card -> { + TFile file = new TFile(CardImageUtils.generateImagePath(card)); if (!file.exists()) { logger.debug("Missing: " + file.getAbsolutePath()); cardsToDownload.add(card); } - } + }); logger.info("Check download images (total cards: " + numberCardImages + ", total tokens: " + numberTokenImages + ") => Missing images: " + cardsToDownload.size()); if (logger.isDebugEnabled()) { @@ -388,7 +384,7 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab } } - return cardsToDownload; + return new ArrayList<>(cardsToDownload); } private static ArrayList getTokenCardUrls() throws RuntimeException { @@ -502,7 +498,7 @@ public class DownloadPictures extends DefaultBoundedRangeModel implements Runnab if (p != null) { HashSet ignoreUrls = SettingsManager.getIntance().getIgnoreUrls(); - ArrayList cardsToDownload = this.checkBox.isSelected() ? type2cards : cards; + List cardsToDownload = this.checkBox.isSelected() ? type2cards : cards; update(0, cardsToDownload.size());