本文整理匯總了Java中java.util.concurrent.Executors類的典型用法代碼示例。如果您正苦於以下問題:Java Executors類的具體用法?Java Executors怎麽用?Java Executors使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Executors類屬於java.util.concurrent包,在下文中一共展示了Executors類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: testBug75615
import java.util.concurrent.Executors; //導入依賴的package包/類
public void testBug75615() throws Exception {
// Main use case: although this could cause an exception due to a race condition in MysqlIO.mysqlConnection it is silently swallowed within the running
// thread.
final Connection testConn1 = getConnectionWithProps("");
testConn1.setNetworkTimeout(Executors.newSingleThreadExecutor(), 1000);
testConn1.close();
// Main use case simulation: this simulates the above by capturing an eventual exeption in the main thread. This is where this test would actually fail.
// This part is repeated several times to increase the chance of hitting the reported bug.
for (int i = 0; i < 25; i++) {
final ExecutorService execService = Executors.newSingleThreadExecutor();
final Connection testConn2 = getConnectionWithProps("");
testConn2.setNetworkTimeout(new Executor() {
public void execute(Runnable command) {
// Attach the future to the parent object so that it can track the exception in the main thread.
ConnectionRegressionTest.this.testBug75615Future = execService.submit(command);
}
}, 1000);
testConn2.close();
try {
this.testBug75615Future.get();
} catch (ExecutionException e) {
e.getCause().printStackTrace();
fail("Exception thrown in the thread that was setting the network timeout: " + e.getCause());
}
execService.shutdownNow();
}
// Test the expected exception on null executor.
assertThrows(SQLException.class, "Executor can not be null", new Callable<Void>() {
public Void call() throws Exception {
Connection testConn = getConnectionWithProps("");
testConn.setNetworkTimeout(null, 1000);
testConn.close();
return null;
}
});
}
示例2: setUp
import java.util.concurrent.Executors; //導入依賴的package包/類
@Override protected void setUp() {
final ExecutorService executor = Executors.newSingleThreadExecutor();
tearDownStack.addTearDown(new TearDown() {
@Override
public void tearDown() {
executor.shutdownNow();
}
});
sleeper = new SleepingRunnable(1000);
delayedFuture = executor.submit(sleeper, true);
tearDownStack.addTearDown(new TearDown() {
@Override
public void tearDown() {
Thread.interrupted();
}
});
}
示例3: newThread
import java.util.concurrent.Executors; //導入依賴的package包/類
@Override
public Thread newThread(final Runnable r) {
return Executors.defaultThreadFactory().newThread(new Runnable() {
@Override
public void run() {
Thread.currentThread().setName("JavaCronetEngine");
// On android, all background threads (and all threads that are part
// of background processes) are put in a cgroup that is allowed to
// consume up to 5% of CPU - these worker threads spend the vast
// majority of their time waiting on I/O, so making them contend with
// background applications for a slice of CPU doesn't make much sense.
// We want to hurry up and get idle.
android.os.Process.setThreadPriority(
THREAD_PRIORITY_BACKGROUND + THREAD_PRIORITY_MORE_FAVORABLE);
r.run();
}
});
}
示例4: testSValue
import java.util.concurrent.Executors; //導入依賴的package包/類
@Test
public void testSValue() throws Exception {
// Check that we never generate an S value that is larger than half the curve order. This avoids a malleability
// issue that can allow someone to change a transaction [hash] without invalidating the signature.
final int ITERATIONS = 10;
ListeningExecutorService executor = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(ITERATIONS));
List<ListenableFuture<ECKey.ECDSASignature>> sigFutures = Lists.newArrayList();
final ECKey key = new ECKey();
for (byte i = 0; i < ITERATIONS; i++) {
final byte[] hash = HashUtil.sha3(new byte[]{i});
sigFutures.add(executor.submit(new Callable<ECDSASignature>() {
@Override
public ECKey.ECDSASignature call() throws Exception {
return key.doSign(hash);
}
}));
}
List<ECKey.ECDSASignature> sigs = Futures.allAsList(sigFutures).get();
for (ECKey.ECDSASignature signature : sigs) {
assertTrue(signature.s.compareTo(ECKey.HALF_CURVE_ORDER) <= 0);
}
final ECKey.ECDSASignature duplicate = new ECKey.ECDSASignature(sigs.get(0).r, sigs.get(0).s);
assertEquals(sigs.get(0), duplicate);
assertEquals(sigs.get(0).hashCode(), duplicate.hashCode());
}
示例5: main
import java.util.concurrent.Executors; //導入依賴的package包/類
public static void main(String[] args) throws InterruptedException
{
// create new thread pool with two threads
ExecutorService executorService = Executors.newCachedThreadPool();
// create SynchronizedBuffer to store ints
Buffer sharedLocation = new SynchronizedBuffer();
System.out.printf("%-40s%s\t\t%s%n%-40s%s%n%n", "Operation",
"Buffer", "Occupied", "---------", "------\t\t--------");
// execute the Producer and Consumer tasks
executorService.execute(new Producer(sharedLocation));
executorService.execute(new Consumer(sharedLocation));
executorService.shutdown();
executorService.awaitTermination(1, TimeUnit.MINUTES);
}
示例6: testSubmitPrivilegedExceptionAction
import java.util.concurrent.Executors; //導入依賴的package包/類
/**
* A submitted privileged exception action runs to completion
*/
public void testSubmitPrivilegedExceptionAction() throws Exception {
final Callable callable =
Executors.callable(new PrivilegedExceptionAction() {
public Object run() { return TEST_STRING; }});
Runnable r = new CheckedRunnable() {
public void realRun() throws Exception {
ExecutorService e = new ForkJoinPool(1);
try (PoolCleaner cleaner = cleaner(e)) {
Future future = e.submit(callable);
assertSame(TEST_STRING, future.get());
}
}};
runWithPermissions(r, new RuntimePermission("modifyThread"));
}
示例7: schedule
import java.util.concurrent.Executors; //導入依賴的package包/類
/**
* 定時清數據
*/
private void schedule() {
ScheduledExecutorService scheduledExecutorService = Executors.newSingleThreadScheduledExecutor(new NamedThreadFactory("recoder"));
scheduledExecutorService.scheduleAtFixedRate(new Runnable() {
public void run() {
try {
CallbackRecoder.recordTime();
CallbackRecoder.calCallbackCount();
RequestRecoder.calProviderRegistryCount();
RequestRecoder.calConsumerRegistryCount();
IpRequestHandler.calAllCount();
sendMonitorData();
} catch (Exception e) {
logger.error(e.getMessage(), e);
}
}
}, getDelaySecond(), interval, TimeUnit.SECONDS);
}
示例8: reentrantlock
import java.util.concurrent.Executors; //導入依賴的package包/類
private void reentrantlock() {
ExecutorService executor = Executors.newFixedThreadPool(2);
ReentrantLock lock = new ReentrantLock();
executor.submit(() -> {
lock.lock();
try {
sleep(1);
} finally {
lock.unlock();
}
});
executor.submit(() -> {
System.out.println("Locked: " + lock.isLocked());
System.out.println("Held by me: " + lock.isHeldByCurrentThread());
boolean locked = lock.tryLock();
System.out.println("Lock acquired: " + locked);
});
stop(executor);
}
示例9: init
import java.util.concurrent.Executors; //導入依賴的package包/類
@Override
public void init() {
if (config.listenPort() > 0) {
peerServiceExecutor = Executors.newSingleThreadExecutor(runnable -> {
Thread thread = new Thread(runnable, "Peer Server");
thread.setUncaughtExceptionHandler((exceptionThread, exception) -> {
gLogger.error("Unable to start peer server", exception);
});
return thread;
});
peerServiceExecutor.execute(() -> peerServer.start(config.listenPort()));
}
compositeEthereumListener.addListener(gasPriceTracker);
gLogger.info("RskJ node started: enode://{}@{}:{}" , Hex.toHexString(config.nodeId()), config.getExternalIp(), config.listenPort());
}
示例10: multiThreadedSavePdfTablePageDebugImage
import java.util.concurrent.Executors; //導入依賴的package包/類
@Test
public void multiThreadedSavePdfTablePageDebugImage() throws IOException {
long start = System.currentTimeMillis();
PdfTableReader reader = new PdfTableReader();
ExecutorService executor = Executors.newFixedThreadPool(THREAD_COUNT);
List<Future<Boolean>> futures = new ArrayList<>();
for (final int pageNum : IntStream.rangeClosed(1, PDFdoc.getNumberOfPages()).toArray()) {
Callable<Boolean> callable = () -> {
reader.savePdfTablePageDebugImage(PDFdoc, pageNum, TEST_OUT_PATH);
return true;
};
futures.add(executor.submit(callable));
}
try {
for (Future<Boolean> f : futures) {
f.get();
}
} catch (Exception e) {
throw new TestException(e);
}
long end = System.currentTimeMillis();
System.out.println("save debug images - multi thread: " + (end - start) / 1000.0);
}
示例11: initDisruptor
import java.util.concurrent.Executors; //導入依賴的package包/類
private void initDisruptor(int processors, int ringBufferSize) {
LOG.info("eds client init disruptor with processors="
+ processors + " and ringBufferSize=" + ringBufferSize);
executor = Executors.newFixedThreadPool(
processors,
new ThreadFactoryBuilder().setNameFormat("disruptor-executor-%d").build());
final WaitStrategy waitStrategy = createWaitStrategy();
ringBufferSize = sizeFor(ringBufferSize); // power of 2
disruptor = new Disruptor<>(EdsRingBufferEvent.FACTORY, ringBufferSize, executor,
ProducerType.MULTI, waitStrategy);
EdsEventWorkHandler[] handlers = new EdsEventWorkHandler[processors];
for (int i = 0; i < handlers.length; i++) {
handlers[i] = new EdsEventWorkHandler();
}
// handlers number = threads number
disruptor.handleEventsWithWorkerPool(handlers); // "handleEventsWith" just like topics , with multiple consumers
disruptor.start();
}
示例12: RemotingNettyClient
import java.util.concurrent.Executors; //導入依賴的package包/類
private RemotingNettyClient(final NettyClientConfig nettyClientConfig) {
super(nettyClientConfig.getOnewaySemaphoreValue(), nettyClientConfig.getAsyncSemaphoreValue());
int publicThreadNums = nettyClientConfig.getCallbackExecutorThreads();
if (publicThreadNums <= 0) {
publicThreadNums = 4;
}
this.publicExecutor = Executors.newFixedThreadPool(publicThreadNums, new ThreadFactory() {
private AtomicInteger threadIndex = new AtomicInteger(0);
@Override
public Thread newThread(Runnable r) {
return new Thread(r, "NettyClientPublicExecutor_" + this.threadIndex.incrementAndGet());
}
});
group = new NioEventLoopGroup(nettyClientConfig.getWorkerThreads(), new CustomThreadFactory("client"));
start();
}
示例13: setup
import java.util.concurrent.Executors; //導入依賴的package包/類
@Setup
public void setup() {
ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
executor.schedule(
() -> {
System.out.println("Deoptimize: 1");
state = 1;
},
25, TimeUnit.SECONDS);
executor.schedule(
() -> {
System.out.println("Deoptimize :0");
state = 0;
},
30, TimeUnit.SECONDS);
}
示例14: init
import java.util.concurrent.Executors; //導入依賴的package包/類
/**
* Initial MiniDownloader.
*
* @param context
*/
public void init(Context context) {
this.appContext = context.getApplicationContext();
/** Create work executor. */
this.workExecutor = new ThreadPoolExecutor(Runtime.getRuntime().availableProcessors(), Runtime.getRuntime().availableProcessors(), 0L, TimeUnit.MILLISECONDS, new PriorityBlockingQueue<Runnable>()) {
@Override
protected <T> RunnableFuture<T> newTaskFor(Callable<T> callable) {
if (callable instanceof CustomFutureCallable) {
return ((CustomFutureCallable) callable).newTaskFor();
}
return super.newTaskFor(callable);
}
};
/** Create command executor. */
this.commandExecutor = Executors.newSingleThreadExecutor();
/** Create and initial task manager. */
taskManager = new TaskManager();
taskManager.init(context);
/** Create and start ProgressUpdater. */
progressUpdater = new ProgressUpdater();
progressUpdater.start();
}
示例15: whileOutLog
import java.util.concurrent.Executors; //導入依賴的package包/類
private void whileOutLog(String outs) {
ser = Executors.newSingleThreadExecutor();
ser.execute(new Runnable() {
@Override
public void run() {
while (true) {
try {
logger.info("Test HBase insert Log info-" + new Date());
Thread.sleep(5000);
}
catch (InterruptedException e) {
}
}
}
});
}