本文整理匯總了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);
}
}
示例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());
}
示例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);
}
示例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());
}
示例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;
}
示例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;
}
示例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);
}
示例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());
}
示例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());
}
示例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;
}
示例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())));
}
示例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();
}
示例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));
}
示例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.
}
}
示例15: Builder
import com.google.common.collect.Maps; //導入方法依賴的package包/類
private Builder(final ResultMap res) {
this.res = res;
this.map = Maps.newConcurrentMap();
}