當前位置: 首頁>>代碼示例>>Java>>正文


Java ExecutorService.execute方法代碼示例

本文整理匯總了Java中java.util.concurrent.ExecutorService.execute方法的典型用法代碼示例。如果您正苦於以下問題:Java ExecutorService.execute方法的具體用法?Java ExecutorService.execute怎麽用?Java ExecutorService.execute使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.ExecutorService的用法示例。


在下文中一共展示了ExecutorService.execute方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testOfferInExecutor

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public void testOfferInExecutor(boolean fair) {
    final SynchronousQueue q = new SynchronousQueue(fair);
    final CheckedBarrier threadsStarted = new CheckedBarrier(2);
    final ExecutorService executor = Executors.newFixedThreadPool(2);
    try (PoolCleaner cleaner = cleaner(executor)) {

        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                assertFalse(q.offer(one));
                threadsStarted.await();
                assertTrue(q.offer(one, LONG_DELAY_MS, MILLISECONDS));
                assertEquals(0, q.remainingCapacity());
            }});

        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                threadsStarted.await();
                assertSame(one, q.take());
            }});
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:22,代碼來源:SynchronousQueueTest.java

示例2: testPollInExecutor

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * timed poll retrieves elements across Executor threads
 */
public void testPollInExecutor() {
    final LinkedTransferQueue q = new LinkedTransferQueue();
    final CheckedBarrier threadsStarted = new CheckedBarrier(2);
    final ExecutorService executor = Executors.newFixedThreadPool(2);
    try (PoolCleaner cleaner = cleaner(executor)) {

        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                assertNull(q.poll());
                threadsStarted.await();
                long startTime = System.nanoTime();
                assertSame(one, q.poll(LONG_DELAY_MS, MILLISECONDS));
                assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS);
                checkEmpty(q);
            }});

        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                threadsStarted.await();
                q.put(one);
            }});
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:27,代碼來源:LinkedTransferQueueTest.java

示例3: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) {
    //創建並發訪問的賬戶
    MyCount myCount = new MyCount("95599200901215522", 10000);
    //創建一個鎖對象
    ReadWriteLock lock = new ReentrantReadWriteLock(false);
    //創建一個線程池
    ExecutorService pool = Executors.newFixedThreadPool(2);
    //創建一些並發訪問用戶,一個信用卡,存的存,取的取,好熱鬧啊
    User u1 = new User("張三", myCount, -4000, lock, true);
    User u2 = new User("張三他爹", myCount, 6000, lock, false);
    User u3 = new User("張三他弟", myCount, -8000, lock, false);
    User u4 = new User("張三", myCount, 800, lock, false);
    User u5 = new User("張三他爹", myCount, 0, lock, true);
    //在線程池中執行各個用戶的操作
    pool.execute(u1);
    pool.execute(u2);
    pool.execute(u3);
    pool.execute(u4);
    pool.execute(u5);
    //關閉線程池
    pool.shutdown();
}
 
開發者ID:sean417,項目名稱:LearningOfThinkInJava,代碼行數:23,代碼來源:ReadWriteLockDemo1.java

示例4: startClient

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public void startClient()
{
   try // connect to server and get streams
   {
      // make connection to server
      connection = new Socket(
         InetAddress.getByName(ticTacToeHost), 12345);

      // get streams for input and output
      input = new Scanner(connection.getInputStream());
      output = new Formatter(connection.getOutputStream());
   } 
   catch (IOException ioException)
   {
      ioException.printStackTrace();         
   } 

   // create and start worker thread for this client
   ExecutorService worker = Executors.newFixedThreadPool(1);
   worker.execute(this); // execute client
}
 
開發者ID:cleitonferreira,項目名稱:LivroJavaComoProgramar10Edicao,代碼行數:22,代碼來源:TicTacToeClient.java

示例5: generateMaxSet

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
private void generateMaxSet() throws AlgorithmExecutionException {

        if (this.optimize()) {
            this.maxSet = new CopyOnWriteArrayList<MAX_SET>();
            ExecutorService exec = this.getExecuter();
            for (int i = 0; i < this.numberOfAttributes; ++i) {
                exec.execute(new RunnerThreadMaxSet(i));
            }
            this.awaitExecuter(exec);
        } else {
            this.maxSet = new LinkedList<MAX_SET>();
            for (int i = 0; i < this.numberOfAttributes; ++i) {
                executeMax_Set_Task(i);
            }
        }

    }
 
開發者ID:HPI-Information-Systems,項目名稱:metanome-algorithms,代碼行數:18,代碼來源:CMAX_SET_Generator.java

示例6: testPollInExecutor

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * timed poll transfers elements across Executor tasks
 */
public void testPollInExecutor() {
    final DelayQueue q = new DelayQueue();
    final CheckedBarrier threadsStarted = new CheckedBarrier(2);
    final ExecutorService executor = Executors.newFixedThreadPool(2);
    try (PoolCleaner cleaner = cleaner(executor)) {
        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                assertNull(q.poll());
                threadsStarted.await();
                assertNotNull(q.poll(LONG_DELAY_MS, MILLISECONDS));
                checkEmpty(q);
            }});

        executor.execute(new CheckedRunnable() {
            public void realRun() throws InterruptedException {
                threadsStarted.await();
                q.put(new PDelay(1));
            }});
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:DelayQueueTest.java

示例7: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) throws Throwable {
    final int nThreads = 16;
    final int writes = 1000;
    final File file = File.createTempFile("foo", null);
    try {
        ExecutorService pool = Executors.newFixedThreadPool(nThreads);
        for (int i = 0; i < nThreads; i++)
            pool.execute(new Runnable() { public void run() {
                try {
                    // randomly choose FileChannel or OutputStream
                    if (rand.nextBoolean()) {
                        try (FileChannel fc = newFileChannel(file)) {
                            for (int j=0; j<writes; j++) write(fc, 'x');
                        }
                    } else {
                        try (OutputStream out = newOutputStream(file)) {
                            for (int j = 0; j<writes; j++) out.write('x');
                        }
                    }
                } catch (IOException ioe) {
                    ioe.printStackTrace();
                }
            }});
        pool.shutdown();
        pool.awaitTermination(1L, TimeUnit.MINUTES);
        if (file.length() != (long) (nThreads * writes))
            throw new RuntimeException("File not expected length");
    } finally {
        file.delete();
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:32,代碼來源:AtomicAppend.java

示例8: getPage

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/** 根據Id查詢(cls返回類型Class) */
public <K> Page<K> getPage(final Page<Long> ids, final Class<K> cls) {
	if (ids != null) {
		Page<K> page = new Page<K>(ids.getCurrent(), ids.getSize());
		page.setTotal(ids.getTotal());
		final List<K> records = InstanceUtil.newArrayList();
		for (int i = 0; i < ids.getRecords().size(); i++) {
			records.add(null);
		}
		int thread = Math.min(maxThread, Math.max(1, records.size() / 2));
		ExecutorService executorService = Executors.newFixedThreadPool(thread);
		for (int i = 0; i < ids.getRecords().size(); i++) {
			final int index = i;
			executorService.execute(new Runnable() {
				public void run() {
					T t = queryById(ids.getRecords().get(index));
					K k = InstanceUtil.to(t, cls);
					records.set(index, k);
				}
			});
		}
		executorService.shutdown();
		try {
			executorService.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
		} catch (InterruptedException e) {
			logger.error("awaitTermination", "", e);
		}
		page.setRecords(records);
		return page;
	}
	return new Page<K>();
}
 
開發者ID:youngMen1,項目名稱:JAVA-,代碼行數:33,代碼來源:BaseService.java

示例9: scanportsetfun

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public void scanportsetfun() {
   	 int threadNum;
        threadNum=Integer.parseInt(TheardNum.getText().trim());
        String[] portsString = textportlist.getText().split(",");
        
        int[] ports = new int[portsString.length];
        
        for(int ii=0;ii<portsString.length;ii++)
            ports[ii] = Integer.parseInt(portsString[ii].trim());
        
        Result.append("scanning"+" "+Lsaportscan.hostaddress+"'s port set!"+"\n");
        ExecutorService threadPool = Executors.newCachedThreadPool();
        for (int i = 0; i < threadNum; i++) {
        	 Portset portset = new Portset(ports,threadNum,i);
         	 threadPool.execute(portset);
        }
        
        threadPool.shutdown();
        
        while (true) {
         	
            if (threadPool.isTerminated()) {
                //System.out.println("OVER!!!!!!!!!!!!!!!");
                Result.append("-------------------------Over!!!----------------------\n\n");
                stateResult.setText("OVER !");  
                break;
            }
        
            try {
               		Thread.sleep(1000);
            } catch (InterruptedException e1) {
        }  
    }
}
 
開發者ID:theLSA,項目名稱:lsascan_v1.0_linux,代碼行數:35,代碼來源:Lsascan_v1_frame.java

示例10: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    String passPath = "password.txt";
    String dictPath = "dictionary.txt";

    System.out.println("Loading dictionary");

    List<String> dictionary = new ArrayList<String>();

    // store dictionary file in memory
    try (BufferedReader reader = new BufferedReader(new FileReader(dictPath))) {
        String line;
        while ((line = reader.readLine()) != null) {
            dictionary.add(line);
        }
    } catch (IOException e) {
        e.printStackTrace();
    }

    System.out.println("Dictionary loaded");

    ExecutorService executor = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());

    // queue of items (containing a word and it's hash equivalent) added to by producers, taken by consumer
    BlockingQueue<Item> queue = new LinkedBlockingQueue<Item>();

    // checks given hashed word from producers against hashes stored in password text file
    // single consumer serialises writes, avoids concurrent mangling of output file
    Runnable consumer = new Consumer(queue, passPath);
    executor.execute(consumer);
    System.out.println("Consumer started");

    // each thread has increasing approximate computation time based on i
    for (int i = 1; i <= 20; i++) {
        // hashes words from those stored in dictionary text file, sends to consumer to check
        Runnable producer = new Producer(queue, dictionary, i);
        executor.execute(producer);
        System.out.println("Producer " + i + " started");
    }

}
 
開發者ID:jmblixt3,項目名稱:Clash-Royale,代碼行數:41,代碼來源:Driver.java

示例11: testDubboMultiThreadInvoke

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public void testDubboMultiThreadInvoke() throws Exception
{
    Exporter<?> rpcExporter = protocol.export(proxy.getInvoker(new DemoServiceImpl(), DemoService.class, URL.valueOf("dubbo://127.0.0.1:20259/TestService")));
	
	final AtomicInteger counter = new AtomicInteger();
	final DemoService service = proxy.getProxy(protocol.refer(DemoService.class, URL.valueOf("dubbo://127.0.0.1:20259/TestService")));
	assertEquals(service.getSize(new String[]{"123", "456", "789"}), 3);

	final StringBuffer sb = new StringBuffer();
	for(int i=0;i<1024*64+32;i++)
		sb.append('A');
	assertEquals(sb.toString(), service.echo(sb.toString()));

	ExecutorService exec = Executors.newFixedThreadPool(10);
	for(int i=0;i<10;i++)
	{
		final int fi = i;
		exec.execute(new Runnable(){
			public void run()
			{
				for(int i=0;i<30;i++)
				{
					System.out.println(fi+":"+counter.getAndIncrement());
					assertEquals(service.echo(sb.toString()), sb.toString());
				}
			}
		});
	}
	exec.shutdown();
	exec.awaitTermination(10, TimeUnit.SECONDS);
	rpcExporter.unexport();
}
 
開發者ID:zhuxiaolei,項目名稱:dubbo2,代碼行數:33,代碼來源:MultiThreadTest.java

示例12: testMultiInstanceConcurrencySequentiallyLaunched

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
protected void testMultiInstanceConcurrencySequentiallyLaunched(int iterations, final RedissonRunnable runnable) throws InterruptedException {
    System.out.println("Multi Instance Concurrent Job Interation: " + iterations);
    ExecutorService executor = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors() * 2);

    final Map<Integer, RedissonClient> instances = new HashMap<Integer, RedissonClient>();
    for (int i = 0; i < iterations; i++) {
        instances.put(i, BaseTest.createInstance());
    }

    long watch = System.currentTimeMillis();
    for (int i = 0; i < iterations; i++) {
        final int n = i;
        executor.execute(() -> runnable.run(instances.get(n)));
    }

    executor.shutdown();
    Assert.assertTrue(executor.awaitTermination(5, TimeUnit.MINUTES));

    System.out.println("multi: " + (System.currentTimeMillis() - watch));

    executor = Executors.newCachedThreadPool();

    for (final RedissonClient redisson : instances.values()) {
        executor.execute(() -> redisson.shutdown());
    }

    executor.shutdown();
    Assert.assertTrue(executor.awaitTermination(5, TimeUnit.MINUTES));
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:30,代碼來源:BaseConcurrentTest.java

示例13: go

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * 啟動多線程查詢
 */
public void go() {
    ExecutorService executorService = Executors.newFixedThreadPool(Integer.parseInt(Constant.THREAD_POOL_SIZE));
    for (int i = 0; i < Integer.parseInt(Constant.THREAD_NUM); ++i) {
        log.info("thread " + i + " is ready start!");

        executorService.execute(new Task());

        log.info("thread " + i + " has finished!");
    }
    executorService.shutdown();
}
 
開發者ID:Transwarp-DE,項目名稱:Transwarp-Sample-Code,代碼行數:15,代碼來源:Manager.java

示例14: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
     * @param args
     */
    public static void main(String[] args) {
        final List<Integer> list = new ArrayList<Integer>(52);
        
        ExecutorService service = Executors.newFixedThreadPool(50);
        
        int i = 0;
        while (i++ < 50) {
            service.execute(new Runnable() {
                
                @Override
                public void run() {
//                    while (true) {
//                        try {
//                            Thread.sleep(10);
//                        } catch (InterruptedException e) {
//                            // TODO Auto-generated catch block
//                            e.printStackTrace();
//                        }
                        Random r = new Random();
                        list.add(r.nextInt(30));
//                    }
                }
            });
        }
        
        while(true) {
            System.out.println(list.size());
        }
    }
 
開發者ID:tiglabs,項目名稱:jsf-core,代碼行數:33,代碼來源:TestList.java

示例15: run

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * Runs the command.
 *
 * @param command the list of command line tokens
 * @return the output of the command as a list of lines
 * @throws GradleException if the command exited with non-zero exit code
 */
public List<String> run(List<String> command) throws IOException, InterruptedException {
  if (logger != null) {
    logger.debug("Running command : " + String.join(" ", command));
  }

  ExecutorService executor = executorServiceFactory.createExecutorService();

  // Builds the command to execute.
  ProcessBuilder processBuilder = processBuilderFactory.createProcessBuilder();
  processBuilder.command(command);
  processBuilder.redirectErrorStream(true);
  if (environment != null) {
    processBuilder.environment().putAll(environment);
  }
  final Process process = processBuilder.start();

  // Runs the command and streams the output.
  List<String> output = new ArrayList<>();
  executor.execute(outputConsumerRunnable(process, output));
  int exitCode = process.waitFor();

  // Shuts down the executor.
  executor.shutdown();

  try {
    executor.awaitTermination(TIMEOUT_SECONDS, TimeUnit.SECONDS);
  } catch (InterruptedException ex) {
    if (logger != null) {
      logger.debug("Task Executor interrupted waiting for output consumer thread");
    }
  }

  // Stops the build if the command fails to do something, we may want to make this configurable.
  if (exitCode != 0) {
    throw new GradleException("command exited with non-zero exit code : " + exitCode);
  }

  return output;
}
 
開發者ID:GoogleCloudPlatform,項目名稱:minikube-build-tools-for-java,代碼行數:47,代碼來源:CommandExecutor.java


注:本文中的java.util.concurrent.ExecutorService.execute方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。