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


Java ScheduledExecutorService.schedule方法代碼示例

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


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

示例1: tokenSession

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public void tokenSession(String token, Countly.CountlyMessagingMode mode) {
    checkInternalState();

    final String data = "app_key=" + appKey_
            + "&timestamp=" + Countly.currentTimestampMs()
            + "&hour=" + Countly.currentHour()
            + "&dow=" + Countly.currentDayOfWeek()
            + "&token_session=1"
            + "&android_token=" + token
            + "&test_mode=" + (mode == Countly.CountlyMessagingMode.TEST ? 2 : 0)
            + "&locale=" + DeviceInfo.getLocale()
            + "&sdk_version=" + Countly.COUNTLY_SDK_VERSION_STRING
            + "&sdk_name=" + Countly.COUNTLY_SDK_NAME;

    // To ensure begin_session will be fully processed by the server before token_session
    final ScheduledExecutorService worker = Executors.newSingleThreadScheduledExecutor();
    worker.schedule(new Runnable() {
        @Override
        public void run() {
            store_.addConnection(data);
            tick();
        }
    }, 10, TimeUnit.SECONDS);
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:25,代碼來源:ConnectionQueue.java

示例2: startTimer

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
private static void startTimer(View v, final int minutes, Context c) {
    final String impossible = c.getString(R.string.impossible);
    final String minute = c.getString(R.string.minute);
    final String minutess = c.getString(R.string.minutes);
    final String stop = c.getString(R.string.stop);
    final String minuteTxt;
    final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
    final int delay = (minutes * 60) * 1000;
    if (delay == 0) {
        Toast.makeText(c, impossible, Toast.LENGTH_LONG).show();
        return;
    }
    if (minutes < 10) {
        minuteTxt = minute;
    } else {
        minuteTxt = minutess;
    }
    mTask = scheduler.schedule(new runner(c), delay, TimeUnit.MILLISECONDS);
    Toast.makeText(c, stop + " " + minutes + " " + minuteTxt, Toast.LENGTH_LONG).show();
    running = true;
    setState(true);
    reduceVolume(delay);
}
 
開發者ID:RajneeshSingh007,項目名稱:MusicX-music-player,代碼行數:24,代碼來源:Sleeptimer.java

示例3: main

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) {
	Monitor monitor = createMonitor();

	MonitorServer server = MonitorServer
			.create(monitor::currentStatistics)
			.start();

	ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
	scheduler.scheduleAtFixedRate(monitor::updateStatistics, 1, 1, TimeUnit.SECONDS);
	scheduler.schedule(() -> {
				scheduler.shutdown();
				server.shutdown();
			},
			10,
			TimeUnit.SECONDS);
}
 
開發者ID:CodeFX-org,項目名稱:demo-jpms-monitor,代碼行數:17,代碼來源:Main.java

示例4: scheduleTimeout

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public void scheduleTimeout(ScheduledExecutorService timer, final Runnable timeoutCallback, TimeValue timeValue) {
    synchronized (this) {
        if (timeoutFuture != null) {
            throw new IllegalStateException("scheduleTimeout may only be called once");
        }
        if (started == false) {
            timeoutFuture = timer.schedule(new Runnable() {
                @Override
                public void run() {
                    if (remove(TieBreakingPrioritizedRunnable.this)) {
                        runAndClean(timeoutCallback);
                    }
                }
            }, timeValue.nanos(), TimeUnit.NANOSECONDS);
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:18,代碼來源:PrioritizedEsThreadPoolExecutor.java

示例5: testNewSingleThreadScheduledExecutor

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
/**
 * a newSingleThreadScheduledExecutor successfully runs delayed task
 */
public void testNewSingleThreadScheduledExecutor() throws Exception {
    final ScheduledExecutorService p = Executors.newSingleThreadScheduledExecutor();
    try (PoolCleaner cleaner = cleaner(p)) {
        final CountDownLatch proceed = new CountDownLatch(1);
        final Runnable task = new CheckedRunnable() {
            public void realRun() {
                await(proceed);
            }};
        long startTime = System.nanoTime();
        Future f = p.schedule(Executors.callable(task, Boolean.TRUE),
                              timeoutMillis(), MILLISECONDS);
        assertFalse(f.isDone());
        proceed.countDown();
        assertSame(Boolean.TRUE, f.get(LONG_DELAY_MS, MILLISECONDS));
        assertSame(Boolean.TRUE, f.get());
        assertTrue(f.isDone());
        assertFalse(f.isCancelled());
        assertTrue(millisElapsedSince(startTime) >= timeoutMillis());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:ExecutorsTest.java

示例6: schedule

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
@Override
public Disposable schedule(final Runnable action, long delayTime, TimeUnit unit) {
    if (innerSubscription.isDisposed()) {
        return Disposables.empty();
    }

    final ScheduledAction scheduledAction = new ScheduledAction(action, operationQueue);
    final ScheduledExecutorService executor = IOSScheduledExecutorPool.getInstance();

    Future<?> future;
    if (delayTime <= 0) {
        future = executor.submit(scheduledAction);
    } else {
        future = executor.schedule(scheduledAction, delayTime, unit);
    }

    scheduledAction.add(Disposables.fromFuture(future));
    scheduledAction.addParent(innerSubscription);

    return scheduledAction;
}
 
開發者ID:devjn,項目名稱:RxiOSMOE,代碼行數:22,代碼來源:HandlerThreadScheduler.java

示例7: JdbcQuery

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public JdbcQuery ( final StorageDao jdbcStorageDao, final Filter filter, final ScheduledExecutorService executor, final List<JdbcQuery> openQueries ) throws SQLException, NotSupportedException
{
    openQueries.add ( this );
    this.openQueries = new WeakReference<List<JdbcQuery>> ( openQueries );
    this.jdbcStorageDao = jdbcStorageDao;
    this.resultSet = jdbcStorageDao.queryEvents ( filter );
    this.statement = this.resultSet.getStatement ();
    this.hasMore = this.resultSet.next ();
    this.future = executor.schedule ( new Callable<Boolean> () {
        @Override
        public Boolean call ()
        {
            logger.warn ( "Query '{}' was open for over an hour, or service is being shut down, and will now be closed automatically" );
            dispose ();
            return true;
        }
    }, 1, TimeUnit.HOURS );
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:19,代碼來源:JdbcQuery.java

示例8: startTimeout

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
void startTimeout(final long time, final TimeUnit unit, final ScheduledExecutorService scheduler) {
    this.lock.lock();
    try {
        final ScheduledFuture<?> future = scheduler.schedule(this::cancel, time, unit);

        final ChronoUnit cronut = chronoUnit(unit);
        final Timeout t = new TimeoutBuilder().future(future).finishAt(Instant.now().plus(time, cronut)).build();
        final Timeout old = this.timeout.get();
        this.timeout.set(t);

        // try to cancel as we are replacing the timeout, best effort
        if (old != null) {
            old.future().cancel(false);
        }
    } finally {
        this.lock.unlock();
    }
}
 
開發者ID:groupon,項目名稱:jtier-ctx,代碼行數:19,代碼來源:Life.java

示例9: testNewScheduledThreadPool

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
/**
 * a newScheduledThreadPool successfully runs delayed task
 */
public void testNewScheduledThreadPool() throws Exception {
    final ScheduledExecutorService p = Executors.newScheduledThreadPool(2);
    try (PoolCleaner cleaner = cleaner(p)) {
        final CountDownLatch proceed = new CountDownLatch(1);
        final Runnable task = new CheckedRunnable() {
            public void realRun() {
                await(proceed);
            }};
        long startTime = System.nanoTime();
        Future f = p.schedule(Executors.callable(task, Boolean.TRUE),
                              timeoutMillis(), MILLISECONDS);
        assertFalse(f.isDone());
        proceed.countDown();
        assertSame(Boolean.TRUE, f.get(LONG_DELAY_MS, MILLISECONDS));
        assertSame(Boolean.TRUE, f.get());
        assertTrue(f.isDone());
        assertFalse(f.isCancelled());
        assertTrue(millisElapsedSince(startTime) >= timeoutMillis());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:ExecutorsTest.java

示例10: start

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public void start(){
StringBuilder b;
Path p;
File[] storageLocations = new File[storageTiering.length];
for (int i = 0; i < storageTiering.length; i++) {
    storageLocations[i] = new File(storageTiering[i]);
}  
Runnable clean=()->{
    for (int i = 0; i < index.length(); i++) {
        for (int z = 0; z < storageTiering.length; z++) {
            if (a.get(i).getAccessAverage() < thresholds[z]) {
                b.append(storageTiering[i]);
                b.append("/");
                if (a.get(i).getLocationTier() != 0) {
                    String str = new String(Files.readAllBytes( Paths.get( index.get(i).getPath())));
                    dataStore.put(a.get(i), str);
                    File file=new File(index.get(a).getPath());
                    file.delete();
                }
                b.append(a.get(i).getTitle());
                b.append(".txt");
                p.get(b.toString());
                Files.write(p, dataStore.get(a.get(i)).getBytes());
                index.get(i).setPath(b.toString());
                b.setLength(0);
                index.get(i).setLocationTier(z);
                }
            }
        }
    };
ScheduledExecutorService service=Executors.newScheduledThreadPool(1);
ScheduledFuture future=service.schedule(clean, (long)checkInterval,unit);
}
 
開發者ID:EventHorizon27,項目名稱:dataset-lib,代碼行數:34,代碼來源:StringDataStore.java

示例11: createWindow

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
@Override
public void createWindow(String caption) throws Exception {
    super.createWindow(caption);

    final ProgressIndicatorWindow progressIndicatorWindow = new ProgressIndicatorWindow();

    UI.getCurrent().addWindow(progressIndicatorWindow);
    progressIndicatorWindow.bringToFront();

    Runnable seviceCall = new Runnable() {
        @Override
        public void run() {
            // Make service calls in the UI thread, since the calls will update the UI components
            UI.getCurrent().access(new Runnable() {

                @Override
                public void run() {
                    try {
                        makeServiceCalls(progressIndicatorWindow);
                    } finally {
                        progressIndicatorWindow.close();
                    }
                }
            });
        }
    };
    ScheduledExecutorService exec = Executors.newScheduledThreadPool(1);
    exec.schedule(seviceCall, 1, TimeUnit.MILLISECONDS);
}
 
開發者ID:opensecuritycontroller,項目名稱:osc-core,代碼行數:30,代碼來源:LoadingIndicatorCRUDBaseWindow.java

示例12: main

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) {
    final LoadMonitor monitor = new LoadMonitor(null);
    final ScheduledExecutorService scheduler =
        Executors.newScheduledThreadPool(1);
    final ScheduledFuture<?> monitorTask =
        monitor.startMonitoring(scheduler);
    final ScheduledFuture<?> printTask =
        monitor.printMonitoring(scheduler);

    // Run the tasks for 2 minutes
    scheduler.schedule(
        new Runnable() {
            public void run() {
                monitorTask.cancel(true);
                printTask.cancel(true);
            }
        }, 5*60, TimeUnit.SECONDS);
}
 
開發者ID:nsg-ethz,項目名稱:iTAP-controller,代碼行數:19,代碼來源:LoadMonitor.java

示例13: initialize

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
/**
 * Init the HEOS group. Starts an extra thread to avoid blocking
 * during start up phase. Gathering all information can take longer
 * than 5 seconds which can throw an error within the openhab system.
 */
@Override
public void initialize() {

    this.gid = this.thing.getConfiguration().get(GID).toString();
    api.registerforChangeEvents(this);
    ScheduledExecutorService executerPool = Executors.newScheduledThreadPool(1);
    executerPool.schedule(new InitializationRunnable(), 4, TimeUnit.SECONDS);
    updateStatus(ThingStatus.ONLINE);
    updateState(CH_ID_STATUS, StringType.valueOf(ONLINE));
    super.initialize();

}
 
開發者ID:Wire82,項目名稱:org.openhab.binding.heos,代碼行數:18,代碼來源:HeosGroupHandler.java

示例14: startClients

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
private void startClients(int count, ScheduledExecutorService executorService) {
    for (int i = 0; i < count; i++) {
        executorService.schedule(() -> {
            try {
                new ProcessRunnerImpl().start(CLIENT_START_COMMAND);
            } catch (IOException e) {
                logger.log(Level.SEVERE, e.getMessage());
            }
        }, CLIENT_START_DELAY_SEC + i, TimeUnit.SECONDS);
    }
}
 
開發者ID:vitaly-chibrikov,項目名稱:otus_java_2017_04,代碼行數:12,代碼來源:ServerMain.java

示例15: trialRunEngine

import java.util.concurrent.ScheduledExecutorService; //導入方法依賴的package包/類
/**
 * Trial run of the engine. Shuts down after {@code timeout} seconds after startup.
 *
 * @param engine the engine.
 * @param timeout timeout in seconds.
 */
public static void trialRunEngine(Engine engine, int timeout) {
    final Semaphore semaphore = new Semaphore(0, true);

    // Startup the engine. After startup the engine runs on the threads other than the current one.
    engine.startup();

    try {
        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
        executor.schedule(() -> {
            // Release the semaphore after timeout.
            semaphore.release();
        }, timeout, TimeUnit.SECONDS);

        try {
            // Wait for releasing the semaphore after timeout.
            semaphore.acquire();
        } catch (InterruptedException e) {
            logger.warn("trialRunEngine", e);
        }

        executor.shutdown();
    } finally {
        // Shutdown the engine.
        engine.shutdown();
    }
}
 
開發者ID:softelnet,項目名稱:sponge,代碼行數:33,代碼來源:SpongeUtils.java


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