/* * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * - Neither the name of Oracle nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /* * This source code is provided to illustrate the usage of a given feature * or technique and has been deliberately simplified. Additional steps * required for a production-quality application, such as security checks, * input validation and proper error handling, might not be present in * this sample code. */ package stream.parallel; import java.math.BigInteger; import java.util.concurrent.ThreadLocalRandom; import java.util.stream.IntStream; /** * This demo shows how to use the parallel mode to find several number for given * length prime number. The process easily use a parallel stream to generate * a number of desired length probable prime number. Following with filter * operation to make sure we will get desirable length prime numbers. * * @author tyan */ public class ProbablePrimeNumber { /** * Try to get length from command line. Use the length to create random long * stream, that integer's digit is length. * * @param args This has to be a 1-element or 2-elements array, The first * element must be a positive number, which equals to length of generated * prime number stream. Second element is optional, it will be used as how * many probable prime number that will be generated if it's set. */ private static int DEFAULT_NUM = 1 << 10; public static void main(String[] args) { if (args.length != 1 && args.length != 2) { usage(); return; } try { int expectedLength = Integer.parseInt(args[0]); int size = (args.length == 2) ? Integer.parseInt(args[1]) : DEFAULT_NUM; IntStream.range(0, size). parallel(). mapToObj(i -> BigInteger.probablePrime(expectedLength * 10 / 3 - ThreadLocalRandom.current().nextInt(3), ThreadLocalRandom.current())). filter(c -> c.toString().length() == expectedLength). forEach(prime -> System.out.println("Found a probable prime number :" + prime)); } catch (NumberFormatException nfe) { usage(); } } /** * Usage of this program */ public static void usage() { System.out.println("Usage: java ProbablePrimeNumber lentgh [size]"); System.out.println("size is a positive integer"); } }