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


Java ConcurrentMap.forEach方法代碼示例

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


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

示例1: getConnectionFromDB

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
public Map<UUID, DockerConnection> getConnectionFromDB() throws IOException {
    Map<UUID, DockerConnection> listOfConnections = new HashMap<>();
    File database = new File("./connections.db");
    DB db = DBMaker
            .fileDB(database)
            .transactionEnable()
            .closeOnJvmShutdown()
            .fileChannelEnable()
            .make();
    ConcurrentMap mapa = db.hashMap("map").createOrOpen();
    mapa.forEach((uuid, connection) -> {
        listOfConnections.put((UUID) uuid, (DockerConnection) connection);
    });
    db.close();
    return listOfConnections;

}
 
開發者ID:petrleocompel,項目名稱:docker-dash,代碼行數:18,代碼來源:DockerConnectionService.java

示例2: testMap

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
private void testMap(ConcurrentMap<Integer, Integer> map, Consumer<ConcurrentMap<Integer, Integer>> action)
        throws InterruptedException {
    // put 0's
    fillMap(map, 0);

    // To start working simultaneously
    CyclicBarrier threadStarted = new CyclicBarrier(2);

    // This task puts 1's into map
    CompletableFuture<Void> putter = CompletableFuture.runAsync(
            awaitOn(threadStarted, () -> fillMap(map, 1)),
            executorService);

    // This task performs the map action to remove all 0's from map
    CompletableFuture<Void> remover = CompletableFuture.runAsync(
            awaitOn(threadStarted, () -> action.accept(map)),
            executorService);

    // Wait for both tasks to complete
    CompletableFuture.allOf(putter, remover).join();

    assertEquals(map.size(), SIZE, "Map size incorrect");
    map.forEach((k, v) -> assertEquals(v, (Integer)1));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:25,代碼來源:ConcurrentRemoveIf.java

示例3: testRead

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
public void testRead() {
    final Origin orgin = Instance.singleton(EndPointOrigin.class);
    final ConcurrentMap<String, Record> records = orgin.getRegistryData();
    records.forEach((key, value) -> {
        System.out.println(key);
        System.out.println(value.toJson().encodePrettily());
    });
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:9,代碼來源:EndPointOrginTc.java

示例4: reduce

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
/**
 * Merge two map
 *
 * @param from
 * @param to
 * @param <K>
 * @param <T>
 * @param <V>
 * @return
 */
public static <K, T, V> ConcurrentMap<K, V> reduce(
        final ConcurrentMap<K, T> from,
        final ConcurrentMap<T, V> to) {
    final ConcurrentMap<K, V> result = new ConcurrentHashMap<>();
    from.forEach((key, middle) -> {
        final V value = to.get(middle);
        if (null != value) {
            result.put(key, value);
        }
    });
    return result;
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:23,代碼來源:Statute.java

示例5: exec

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
/**
 * @param map
 * @param fnEach
 * @param <K>
 * @param <V>
 */
static <K, V> void exec(final ConcurrentMap<K, V> map,
                        final BiConsumer<K, V> fnEach) {
    map.forEach((key, value) -> {
        if (null != key && null != value) {
            fnEach.accept(key, value);
        }
    });
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:15,代碼來源:Congregation.java

示例6: EtcdData

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
private EtcdData(final Class<?> clazz) {
    this.clazz = clazz;
    this.logger = Annal.get(clazz);
    // Read configuration
    final JsonObject config = NODE.read();
    if (config.containsKey(KEY)) {
        final JsonObject root = config.getJsonObject(KEY);
        // Verify the data
        Fn.flingUp(() -> Fn.shuntZero(() -> Ruler.verify(KEY, root), root),
                LOGGER);
        if (root.containsKey(TIMEOUT)) {
            this.timeout = root.getLong(TIMEOUT);
        }
        if (root.containsKey(MICRO)) {
            this.application = root.getString(MICRO);
        }
        // Nodes
        if (root.containsKey(NODES)) {
            this.config.addAll(root.getJsonArray(NODES));
        }
        LOGGER.info(Info.ETCD_TIMEOUT,
                this.application, this.timeout, this.config.size());
    }
    Fn.flingUp(this.config.isEmpty(), this.logger,
            EtcdConfigEmptyException.class, this.clazz);

    final Set<URI> uris = new HashSet<>();
    final ConcurrentMap<Integer, String> networks
            = new ConcurrentHashMap<>();
    Observable.fromIterable(this.config)
            .filter(Objects::nonNull)
            .map(item -> (JsonObject) item)
            .filter(item -> item.containsKey(PORT) && item.containsKey(HOST))
            .map(item -> {
                final Integer port = item.getInteger(PORT);
                final String host = item.getString(HOST);
                networks.put(port, host);
                return "http://" + host + ":" + port;
            })
            .map(URI::create)
            .subscribe(uris::add);
    // Network checking
    networks.forEach((port, host) ->
            Fn.flingUp(!Net.isReach(host, port), LOGGER,
                    EtcdNetworkException.class, getClass(), host, port));
    LOGGER.info(Info.ETCD_NETWORK);
    this.client = new EtcdClient(uris.toArray(new URI[]{}));
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:49,代碼來源:EtcdData.java

示例7: each

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
public static void each(
        final BiConsumer<String, VertxOptions> consumer) {
    final ConcurrentMap<String, VertxOptions> vertxOptions
            = ZeroGrid.getVertxOptions();
    vertxOptions.forEach(consumer);
}
 
開發者ID:silentbalanceyh,項目名稱:vertx-zero,代碼行數:7,代碼來源:Motor.java

示例8: getControllers

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
private List<Controller> getControllers(Uuid bridgeUuid) {
        DatabaseSchema dbSchema = schema.get(OvsdbConstant.DATABASENAME);
        if (dbSchema == null) {
            return null;
        }
        OvsdbRowStore rowStore = getRowStore(OvsdbConstant.DATABASENAME,
                                             OvsdbConstant.BRIDGE);
        if (rowStore == null) {
            log.debug("There is no bridge table");
            return null;
        }

        Row bridgeRow = rowStore.getRow(bridgeUuid.value());
        Bridge bridge = (Bridge) TableGenerator.
                getTable(dbSchema, bridgeRow, OvsdbTable.BRIDGE);

        //FIXME remove log
        log.warn("type of controller column", bridge.getControllerColumn()
                .data().getClass());
        Set<Uuid> controllerUuids = (Set<Uuid>) ((OvsdbSet) bridge
                .getControllerColumn().data()).set();
//        Set<String> controllerUuidStrings = (Set<String>) bridge.getControllerColumn().data();

        OvsdbRowStore controllerRowStore = getRowStore(OvsdbConstant.DATABASENAME,
                                                       OvsdbConstant.CONTROLLER);
        if (controllerRowStore == null) {
            log.debug("There is no controller table");
            return null;
        }

        List<Controller> ovsdbControllers = new ArrayList<>();
        ConcurrentMap<String, Row> controllerTableRows = controllerRowStore.getRowStore();
        controllerTableRows.forEach((key, row) -> {
            if (!controllerUuids.contains(Uuid.uuid(key))) {
                return;
            }
            Controller controller = (Controller) TableGenerator
                    .getTable(dbSchema, row, OvsdbTable.CONTROLLER);
            ovsdbControllers.add(controller);
        });
        return ovsdbControllers;
    }
 
開發者ID:shlee89,項目名稱:athena,代碼行數:43,代碼來源:DefaultOvsdbClient.java

示例9: main

import java.util.concurrent.ConcurrentMap; //導入方法依賴的package包/類
/**
 * The main method.
 *
 * @param args
 *            the arguments
 * @throws ParseException
 *             the parse exception
 * @throws IOException
 *             Signals that an I/O exception has occurred.
 */
public static void main(final String args[]) throws ParseException, IOException {

    // Parse CLI options
    final Options options = getCmdOptions();
    final CommandLine cmd = parseCmdOptions(options, args);

    if (cmd == null || cmd.hasOption("h")) {
        final HelpFormatter formatter = new HelpFormatter();
        formatter.printHelp("metarecsys", options);
        System.exit(0);
    }

    final Path runsFolder = Paths.get(cmd.getOptionValue(RUN_OPTION));
    final Path outputFolder = Paths.get(cmd.getOptionValue(OUT_OPTION));
    final int maxRank = Integer.parseInt(cmd.getOptionValue(MAX_OPTION, DEFAULT_MAX_RANK));

    // Build metarecsys algorithms
    final List<RankAggregation> algs = Arrays.stream(cmd.getOptionValues(ALG_OPTION))
            .map(name -> RankAggregation.build(name, maxRank)).collect(Collectors.toList());

    // For each normalisation algorithm
    for (final String norm : cmd.getOptionValues(NORM_OPTION)) {

        // Read runs by fold
        final ConcurrentMap<Integer, List<RunFile>> runsByFold = RunFile.readRuns(runsFolder,
                maxRank, NormalisationAlgorithm.build(norm));

        // For each metarecsys algorithm
        for (final RankAggregation alg : algs) {

            // For each fold
            runsByFold.forEach((fold, runs) -> {
                alg.computeAllCombinations(fold, runs, outputFolder);
            });

        }

    }

    RankAggregation.finishPool();
    Logger.getGlobal().info("Finished!");

}
 
開發者ID:dvalcarce,項目名稱:metarecsys,代碼行數:54,代碼來源:MetaRecSys.java


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