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


Java Maps.newConcurrentMap方法代碼示例

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


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

示例1: registerProperties

import com.google.common.collect.Maps; //導入方法依賴的package包/類
@Override
public void registerProperties(Class<?> componentClass) {
    checkPermission(CONFIG_WRITE);

    String componentName = componentClass.getName();
    String resourceName = componentClass.getSimpleName() + RESOURCE_EXT;
    try (InputStream ris = componentClass.getResourceAsStream(resourceName)) {
        checkArgument(ris != null, "Property definitions not found at resource %s",
                      resourceName);

        // Read the definitions
        Set<ConfigProperty> defs = ConfigPropertyDefinitions.read(ris);

        // Produce a new map of the properties and register it.
        Map<String, ConfigProperty> map = Maps.newConcurrentMap();
        defs.forEach(p -> map.put(p.name(), p));

        properties.put(componentName, map);
        loadExistingValues(componentName);
    } catch (IOException e) {
        log.error("Unable to read property definitions from resource " + resourceName, e);
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:24,代碼來源:ComponentConfigManager.java

示例2: jsonNodeToHostRoutes

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Changes hostRoutes JsonNode to a collection of the hostRoutes.
 *
 * @param hostRoutes the hostRoutes json node
 * @return a collection of hostRoutes
 */
public Iterable<HostRoute> jsonNodeToHostRoutes(JsonNode hostRoutes) {
    checkNotNull(hostRoutes, JSON_NOT_NULL);
    ConcurrentMap<Integer, HostRoute> hostRouteMaps = Maps
            .newConcurrentMap();
    Integer i = 0;
    for (JsonNode node : hostRoutes) {
        IpAddress nexthop = IpAddress.valueOf(node.get("nexthop").asText());
        IpPrefix destination = IpPrefix.valueOf(node.get("destination")
                .asText());
        HostRoute hostRoute = new DefaultHostRoute(nexthop, destination);
        hostRouteMaps.putIfAbsent(i, hostRoute);
        i++;
    }
    return Collections.unmodifiableCollection(hostRouteMaps.values());
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:22,代碼來源:SubnetWebResource.java

示例3: buildFields

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Build content field
 * 
 * @param ddmStructure
 * @param serviceContext
 * @return
 * @throws Exception
 */
public String buildFields(long groupId, DDMStructure ddmStructure, String[] locales) throws Exception {
	
	Map<String, Serializable> fieldsMap = Maps.newConcurrentMap();
	Set<String> fieldNames = ddmStructure.getFieldNames();

	for(String fieldName : fieldNames ) {
		fieldsMap.put(fieldName, "");
	}
	
	Fields fields = _ddmLocalUtil.toFields(
			ddmStructure.getStructureId(), 
			fieldsMap, 
			locales,
			LocaleUtil.getDefault());

	return _journalConverter.getContent(ddmStructure, fields);
}
 
開發者ID:yasuflatland-lf,項目名稱:liferay-dummy-factory,代碼行數:26,代碼來源:JournalUtils.java

示例4: jsonNodeToAllowedAddressPair

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Returns a Object of the currently known infrastructure virtualPort.
 *
 * @param allowedAddressPairs the allowedAddressPairs json node
 * @return a collection of allowedAddressPair
 */
public Collection<AllowedAddressPair> jsonNodeToAllowedAddressPair(JsonNode allowedAddressPairs) {
    checkNotNull(allowedAddressPairs, JSON_NOT_NULL);
    ConcurrentMap<Integer, AllowedAddressPair> allowMaps = Maps
            .newConcurrentMap();
    int i = 0;
    for (JsonNode node : allowedAddressPairs) {
        IpAddress ip = IpAddress.valueOf(node.get("ip_address").asText());
        MacAddress mac = MacAddress.valueOf(node.get("mac_address")
                .asText());
        AllowedAddressPair allows = AllowedAddressPair
                .allowedAddressPair(ip, mac);
        allowMaps.put(i, allows);
        i++;
    }
    log.debug("The jsonNode of allowedAddressPairallow is {}"
            + allowedAddressPairs.toString());
    return Collections.unmodifiableCollection(allowMaps.values());
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:25,代碼來源:VirtualPortWebResource.java

示例5: FinalizerThread

import com.google.common.collect.Maps; //導入方法依賴的package包/類
public FinalizerThread(Map<ClassPath, CacheEntry> cacheEntries, Lock lock) {
    this.setName("Classloader cache reference queue poller");
    this.setDaemon(true);
    this.referenceQueue = new ReferenceQueue<CachedClassLoader>();
    this.cacheEntries = cacheEntries;
    this.cleanups = Maps.newConcurrentMap();
    this.lock = lock;
}
 
開發者ID:lxxlxx888,項目名稱:Reer,代碼行數:9,代碼來源:FinalizerThread.java

示例6: lookupServiceUpdate

import com.google.common.collect.Maps; //導入方法依賴的package包/類
private Map<String, List<GrpcURL>> lookupServiceUpdate(String group) {
  Long lastConsulIndexId =
      lookupGroupServices.get(group) == null ? 0L : lookupGroupServices.get(group);
  String serviceName = GrpcURLUtils.toServiceName(group);
  ConsulServiceResp consulResp = client.lookupHealthService(serviceName, lastConsulIndexId);
  if (consulResp != null) {
    List<ConsulService> consulServcies = consulResp.getSalukiConsulServices();
    boolean updated = consulServcies != null && !consulServcies.isEmpty()
        && consulResp.getConsulIndex() > lastConsulIndexId;
    if (updated) {
      Map<String, List<GrpcURL>> groupProviderUrls = Maps.newConcurrentMap();
      for (ConsulService service : consulServcies) {
        GrpcURL providerUrl = buildURL(service);
        String serviceKey = providerUrl.getServiceKey();
        List<GrpcURL> urlList = groupProviderUrls.get(serviceKey);
        if (urlList == null) {
          urlList = Lists.newArrayList();
          groupProviderUrls.put(serviceKey, urlList);
        }
        urlList.add(providerUrl);
      }
      lookupGroupServices.put(group, consulResp.getConsulIndex());
      return groupProviderUrls;
    }
  }
  return null;
}
 
開發者ID:venus-boot,項目名稱:saluki,代碼行數:28,代碼來源:ConsulRegistry.java

示例7: testGet

import com.google.common.collect.Maps; //導入方法依賴的package包/類
@Test
public void testGet() {
    ExtendedSet<TestValue> set = new ExtendedSet<>(Maps.newConcurrentMap());
    TestValue e1 = new TestValue("foo", 1);
    set.add(e1);
    TestValue lookupValue = new TestValue("foo", 2);
    TestValue setEntry = set.get(lookupValue);
    assertEquals(e1, setEntry);
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:10,代碼來源:ExtendedSetTest.java

示例8: jsonNodeToSecurityGroup

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Returns a collection of virtualPorts.
 *
 * @param securityGroups the virtualPort jsonnode
 * @return a collection of securityGroups
 */
public Collection<SecurityGroup> jsonNodeToSecurityGroup(JsonNode securityGroups) {
    checkNotNull(securityGroups, JSON_NOT_NULL);
    ConcurrentMap<Integer, SecurityGroup> securMaps = Maps
            .newConcurrentMap();
    int i = 0;
    for (JsonNode node : securityGroups) {
        SecurityGroup securityGroup = SecurityGroup
                .securityGroup(node.asText());
        securMaps.put(i, securityGroup);
        i++;
    }
    return Collections.unmodifiableCollection(securMaps.values());
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:20,代碼來源:VirtualPortWebResource.java

示例9: init

import com.google.common.collect.Maps; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
public void init() throws DrillbitStartupException {
  final DrillConfig config = context.getConfig();
  final Collection<Class<? extends StoragePlugin>> pluginClasses =
      PathScanner.scanForImplementations(
          StoragePlugin.class,
          config.getStringList(ExecConstants.STORAGE_ENGINE_SCAN_PACKAGES));
  final String lineBrokenList =
      pluginClasses.size() == 0
      ? "" : "\n\t- " + Joiner.on("\n\t- ").join(pluginClasses);
  logger.debug("Found {} storage plugin configuration classes: {}.",
               pluginClasses.size(), lineBrokenList);
  for (Class<? extends StoragePlugin> plugin : pluginClasses) {
    int i = 0;
    for (Constructor<?> c : plugin.getConstructors()) {
      Class<?>[] params = c.getParameterTypes();
      if(params.length != 3
          || params[1] != DrillbitContext.class
          || !StoragePluginConfig.class.isAssignableFrom(params[0])
          || params[2] != String.class) {
        logger.info("Skipping StoragePlugin constructor {} for plugin class {} since it doesn't implement a [constructor(StoragePluginConfig, DrillbitContext, String)]", c, plugin);
        continue;
      }
      availablePlugins.put(params[0], (Constructor<? extends StoragePlugin>) c);
      i++;
    }
    if (i == 0) {
      logger.debug("Skipping registration of StoragePlugin {} as it doesn't have a constructor with the parameters of (StorangePluginConfig, Config)", plugin.getCanonicalName());
    }
  }

  // create registered plugins defined in "storage-plugins.json"
  this.plugins = Maps.newConcurrentMap();
  this.plugins.putAll(createPlugins());

}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:37,代碼來源:StoragePluginRegistry.java

示例10: getCounters

import com.google.common.collect.Maps; //導入方法依賴的package包/類
@Override
public Map<String, Long> getCounters() {
    Map<String, Long> counters = Maps.newConcurrentMap();
    federatedPrimitiveCreator.getAsyncAtomicCounterNames()
           .forEach(name -> counters.put(name,
                   federatedPrimitiveCreator.newAsyncCounter(name).asAtomicCounter().get()));
    return counters;
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:9,代碼來源:StorageManager.java

示例11: init

import com.google.common.collect.Maps; //導入方法依賴的package包/類
private void init() {

        // Reset any previous state
        synchronized (this) {
            flowRuleGenerated = Boolean.FALSE;
            leafSwitches = Sets.newHashSet();
            spineSwitches = Sets.newHashSet();
            deviceFlowRules = Maps.newConcurrentMap();
            ruleFlags = Maps.newConcurrentMap();
            contextFlags = Maps.newConcurrentMap();
        }

        // Start flow rules generator...
        spawnTask(() -> generateFlowRules(topologyService.currentTopology(), Sets.newHashSet(hostService.getHosts())));
    }
 
開發者ID:shlee89,項目名稱:athena,代碼行數:16,代碼來源:AbstractUpgradableFabricApp.java

示例12: ReactiveRoutingFib

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Class constructor.
 *
 * @param appId application ID to use to generate intents
 * @param hostService host service
 * @param interfaceService interface service
 * @param intentSynchronizer intent synchronization service
 */
public ReactiveRoutingFib(ApplicationId appId, HostService hostService,
                          InterfaceService interfaceService,
                          IntentSynchronizationService intentSynchronizer) {
    this.appId = appId;
    this.hostService = hostService;
    this.interfaceService = interfaceService;
    this.intentSynchronizer = intentSynchronizer;

    routeIntents = Maps.newConcurrentMap();
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:19,代碼來源:ReactiveRoutingFib.java

示例13: initialize

import com.google.common.collect.Maps; //導入方法依賴的package包/類
private void initialize() {
  maxIdScanned = 0;
  publicAppNamespaceCache = new CaseInsensitiveMapWrapper<>(Maps.newConcurrentMap());
  appNamespaceCache = new CaseInsensitiveMapWrapper<>(Maps.newConcurrentMap());
  appNamespaceIdCache = Maps.newConcurrentMap();
  scheduledExecutorService = Executors.newScheduledThreadPool(1, ApolloThreadFactory
      .create("AppNamespaceServiceWithCache", true));
}
 
開發者ID:dewey-its,項目名稱:apollo-custom,代碼行數:9,代碼來源:AppNamespaceServiceWithCache.java

示例14: testBehaviorOfIteratorsCycleConcurrentlyModifyingUnderlyingMap

import com.google.common.collect.Maps; //導入方法依賴的package包/類
/**
 * Just a sanity test of java behaviors.
 *  - Create a concurrent hashmap with 4 entries
 *  - Create a new thread that runs forever cycling over the keys
 *  - In main thread add/remove a bunch of keys
 *  - See that nothing bad happens
 */
@Test
public void testBehaviorOfIteratorsCycleConcurrentlyModifyingUnderlyingMap() throws ExecutionException, InterruptedException {
    final Map<String, String> myMap = Maps.newConcurrentMap();
    myMap.put("Key1", "Value1");
    myMap.put("Key2", "Value2");
    myMap.put("Key3", "Value3");
    myMap.put("Key4", "Value4");

    final Set<String> foundKeys = Sets.newConcurrentHashSet();

    // Create new Thread
    final CompletableFuture<Boolean> future = CompletableFuture.supplyAsync(() -> {
        Iterator<String> keyIterator = Iterators.cycle(myMap.keySet());
        while (keyIterator.hasNext()) {
            final String keyValue = keyIterator.next();
            if (!foundKeys.contains(keyValue)) {
                foundKeys.add(keyValue);
            }
        }
        return false;
    });

    // Wait for a few iterations in the other thread have completed.
    Thread.sleep(200L);

    // Add keys
    for (int x = 5; x < 100; x++) {
        myMap.put("Key" + x, "Value" + x);
    }

    // Sleep for a few
    await()
        .atMost(5, TimeUnit.SECONDS)
        .until(() -> {
            return foundKeys.size();
        }, equalTo(myMap.size()));


    // See that we found all of our keys
    assertEquals("Found all keys", myMap.size(), foundKeys.size());

    // Now remove some keys
    for (int x = 5; x < 100; x++) {
        myMap.remove("Key" + x);
    }

    // Make sure nothing bad happened
    assertFalse("No exceptions thrown", future.isCompletedExceptionally());
    future.cancel(true);
    try {
        future.get();
    } catch (CancellationException e) {
        // We expect an exception because we cancelled it. swallow.
    }
}
 
開發者ID:salesforce,項目名稱:storm-dynamic-spout,代碼行數:63,代碼來源:RoundRobinBufferTest.java

示例15: Builder

import com.google.common.collect.Maps; //導入方法依賴的package包/類
private Builder(final ResultMap res) {
    this.res = res;
    this.map = Maps.newConcurrentMap();
}
 
開發者ID:Zigin,項目名稱:MonitorPlatform,代碼行數:5,代碼來源:ResultMap.java


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