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


Java Collections.synchronizedMap方法代碼示例

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


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

示例1: updateOrganization

import java.util.Collections; //導入方法依賴的package包/類
@CrossOrigin
@RequestMapping(value = "/{id}", method = RequestMethod.PUT)
@ApiOperation(value = "Update an existing organization")
public Map<String, Object> updateOrganization (
		@ApiParam(value = "Updated organization object", required = true) @PathVariable("id") int id,
		@RequestBody @Valid OrganizationDTO organizationDTO) {

   	System.out.println("************** OrganizationController.updateOrganization()" 
               + ": id=" + id  
               + "; organizationDTO=" + organizationDTO 
               + " **************");
   	
	Map<String, Object> responseData = null;
	try {
		OrganizationDTO updatedOrganization = organizationService.updateOrganization(id, organizationDTO);
		responseData = Collections.synchronizedMap(new HashMap<>());
		responseData.put("organization", updatedOrganization);
	} catch (Exception e) {
		System.err.println(e);
	}
	return responseData;
}
 
開發者ID:Code4SocialGood,項目名稱:c4sg-services,代碼行數:23,代碼來源:OrganizationController.java

示例2: FunctionValue

import java.util.Collections; //導入方法依賴的package包/類
public FunctionValue(INExplicitFunctionDefinition def,
	FunctionValue precondition, FunctionValue postcondition,
	Context freeVariables)
{
	this.location = def.location;
	this.name = def.name.getName();
	this.typeValues = null;
	this.type = (TCFunctionType)def.getType();
	this.paramPatternList = def.paramPatternList;
	this.body = def.body;
	this.precondition = precondition;
	this.postcondition = postcondition;
	this.freeVariables = freeVariables;
	this.checkInvariants = !def.isTypeInvariant;
	this.classdef = def.classDefinition;

	if (Settings.measureChecks && def.measure != null)
	{
		measureName = def.measure;
		measureValues = Collections.synchronizedMap(new HashMap<Long, Stack<Value>>());
	}
}
 
開發者ID:nickbattle,項目名稱:FJ-VDMJ,代碼行數:23,代碼來源:FunctionValue.java

示例3: main

import java.util.Collections; //導入方法依賴的package包/類
public static void main(String[] args) {
  //create HashMap object
  HashMap hashMap = new HashMap();

  /*
    Java HashMap is NOT synchronized. To get synchronized Map from
    HashMap use
    static void synchronizedMap(Map map) method of Collections class.
  */

  Map map = Collections.synchronizedMap(hashMap);

  /*
     Use this map object to prevent any unsynchronized access to original
     HashMap object.
  */

}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:19,代碼來源:GetSynchronizedMapFromHashMapExample.java

示例4: clone

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Clones this event.
 *
 * @return cloned event.
 */
@SuppressWarnings("unchecked")
@Override
public AttributeMapEvent clone() {
    AttributeMapEvent event = (AttributeMapEvent) super.clone();
    if (attributes != null) {
        switch (clonePolicy) {
        case SHALLOW:
            event.attributes = Collections.synchronizedMap(new LinkedHashMap<>(attributes));
            break;
        case DEEP:
            event.attributes = (Map<String, Object>) SpongeUtils.deepClone((Serializable) attributes);
            break;
        default:
            throw new SpongeException("Unsupported value: " + clonePolicy);
        }
    }

    return event;
}
 
開發者ID:softelnet,項目名稱:sponge,代碼行數:25,代碼來源:AttributeMapEvent.java

示例5: get

import java.util.Collections; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public Map<SECONDARY_KEY,ITEM> get(Object primaryKey)
{
	Map<SECONDARY_KEY,ITEM> result = super.get( primaryKey );
	if (result != null) return result;
	result = Collections.synchronizedMap( new HashMap<SECONDARY_KEY,ITEM>() );
	super.put( (PRIMARY_KEY)primaryKey, result);
	return result;
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:11,代碼來源:WeakHashMapMap.java

示例6: EngineMap

import java.util.Collections; //導入方法依賴的package包/類
public EngineMap()
{
    this.map = Collections.synchronizedMap(new EnumMap<>(Engine.class));

    final ScriptEngine js = Engine.JAVASCRIPT.newScriptEngine();
    this.map.put(Engine.JAVASCRIPT, js);

    try
    {
        js.eval("engines = {}");
    }
    catch (final ScriptException e)
    {
        throw new RuntimeException(e); // should never happen
    }

    final Bindings engines = (Bindings) js.get("engines");
    engines.put("js", js);

    this.context = js.getContext();
    engines.put("context", this.context);

    for (final Engine engine : Engine.values())
        this.map.computeIfAbsent(engine, e ->
        {
            final ScriptEngine scriptEngine = e.newScriptEngine(this.context);
            ((Bindings) scriptEngine.get("engines")).put(e.getName(), scriptEngine);
            return scriptEngine;
        });
}
 
開發者ID:JDA-Applications,項目名稱:GuildBot,代碼行數:31,代碼來源:EngineMap.java

示例7: AccountsSettings

import java.util.Collections; //導入方法依賴的package包/類
@SuppressLint("UseSparseArrays")
AccountsSettings(Context context) {
    this.app = context.getApplicationContext();
    this.tokens = Collections.synchronizedMap(new HashMap<>(1));
    this.preferences = PreferenceManager.getDefaultSharedPreferences(context);

    Collection<Integer> aids = getRegistered();
    for (Integer aid : aids) {
        String token = preferences.getString(tokenKeyFor(aid), null);

        if (nonEmpty(token)) {
            tokens.put(aid, token);
        }
    }
}
 
開發者ID:PhoenixDevTeam,項目名稱:Phoenix-for-VK,代碼行數:16,代碼來源:AccountsSettings.java

示例8: prepare

import java.util.Collections; //導入方法依賴的package包/類
@Override
public void prepare(Map stormConf, TopologyContext context,
        OutputCollector collector) {

    mode = ConfUtils.getString(stormConf,
            Constants.PARTITION_MODEParamName,
            Constants.PARTITION_MODE_HOST);

    // check that the mode is known
    if (!mode.equals(Constants.PARTITION_MODE_IP)
            && !mode.equals(Constants.PARTITION_MODE_DOMAIN)
            && !mode.equals(Constants.PARTITION_MODE_HOST)) {
        LOG.error("Unknown partition mode : {} - forcing to byHost", mode);
        mode = Constants.PARTITION_MODE_HOST;
    }

    LOG.info("Using partition mode : {}", mode);

    _collector = collector;
    // Register a "MultiCountMetric" to count different events in this bolt
    // Storm will emit the counts every n seconds to a special bolt via a
    // system stream
    // The data can be accessed by registering a "MetricConsumer" in the
    // topology
    this.eventCounter = context.registerMetric("URLPartitioner",
            new MultiCountMetric(), 10);

    final int MAX_ENTRIES = 500;
    cache = new LinkedHashMap(MAX_ENTRIES + 1, .75F, true) {
        // This method is called just after a new entry has been added
        @Override
        public boolean removeEldestEntry(Map.Entry eldest) {
            return size() > MAX_ENTRIES;
        }
    };

    // If the cache is to be used by multiple threads,
    // the cache must be wrapped with code to synchronize the methods
    cache = Collections.synchronizedMap(cache);
}
 
開發者ID:eorliac,項目名稱:patent-crawler,代碼行數:41,代碼來源:URLPartitionerBolt.java

示例9: remove

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Removes the requested map. If the map doesn't exist, returns an empty map.
 */
@Override
public Map<SECONDARY_KEY, Map<TERTIARY_KEY,ITEM>> remove(Object primaryKey)
{
	Map<SECONDARY_KEY, Map<TERTIARY_KEY,ITEM>> result = super.remove(primaryKey);
	if (result != null) { return result; };
	return Collections.synchronizedMap( new HashMapMap<SECONDARY_KEY, TERTIARY_KEY, ITEM>(secondaryCapacity, tertiaryCapacity) );
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:11,代碼來源:HashTriMap.java

示例10: getClassByNameOrNull

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Load a class by name, returning null rather than throwing an exception
 * if it couldn't be loaded. This is to avoid the overhead of creating
 * an exception.
 * 
 * @param name the class name
 * @return the class object, or null if it could not be found.
 */
public Class<?> getClassByNameOrNull(String name) {
  Map<String, WeakReference<Class<?>>> map;
  
  synchronized (CACHE_CLASSES) {
    map = CACHE_CLASSES.get(classLoader);
    if (map == null) {
      map = Collections.synchronizedMap(
        new WeakHashMap<String, WeakReference<Class<?>>>());
      CACHE_CLASSES.put(classLoader, map);
    }
  }

  Class<?> clazz = null;
  WeakReference<Class<?>> ref = map.get(name); 
  if (ref != null) {
     clazz = ref.get();
  }
   
  if (clazz == null) {
    try {
      clazz = Class.forName(name, true, classLoader);
    } catch (ClassNotFoundException e) {
      // Leave a marker that the class isn't found
      map.put(name, new WeakReference<Class<?>>(NEGATIVE_CACHE_SENTINEL));
      return null;
    }
    // two putters can race here, but they'll put the same class
    map.put(name, new WeakReference<Class<?>>(clazz));
    return clazz;
  } else if (clazz == NEGATIVE_CACHE_SENTINEL) {
    return null; // not found
  } else {
    // cache hit
    return clazz;
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:45,代碼來源:Configuration.java

示例11: PublicLocalizer

import java.util.Collections; //導入方法依賴的package包/類
PublicLocalizer(Configuration conf) {
  super("Public Localizer");
  this.lfs = getLocalFileContext(conf);
  this.conf = conf;
  this.pending = Collections.synchronizedMap(
      new HashMap<Future<Path>, LocalizerResourceRequestEvent>());
  this.threadPool = createLocalizerExecutor(conf);
  this.queue = new ExecutorCompletionService<Path>(threadPool);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:10,代碼來源:ResourceLocalizationService.java

示例12: UploadQueueStore

import java.util.Collections; //導入方法依賴的package包/類
@SuppressLint("UseSparseArrays")
UploadQueueStore(@NonNull AppStores base) {
    super(base);
    this.statusUpdatePublishSubject = PublishSubject.create();
    this.queueUpdatesPublishSubject = PublishSubject.create();
    this.timer = Observable.interval(0L, PROGRESS_LOOKUP_DELAY, TimeUnit.MILLISECONDS);
    this.progress = Collections.synchronizedMap(new HashMap<>(0));
}
 
開發者ID:PhoenixDevTeam,項目名稱:Phoenix-for-VK,代碼行數:9,代碼來源:UploadQueueStore.java

示例13: addToPortMap

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Adds a host to the MAC/VLAN->SwitchPort mapping
 * @param sw The switch to add the mapping to
 * @param mac The MAC address of the host to add
 * @param vlan The VLAN that the host is on
 * @param portVal The switchport that the host is on
 */
protected void addToPortMap(IOFSwitch sw, MacAddress mac, VlanVid vlan, OFPort portVal) {
	Map<MacVlanPair, OFPort> swMap = macVlanToSwitchPortMap.get(sw);

	if (vlan == VlanVid.FULL_MASK || vlan == null) {
		vlan = VlanVid.ofVlan(0);
	}

	if (swMap == null) {
		// May be accessed by REST API so we need to make it thread safe
		swMap = Collections.synchronizedMap(new LRULinkedHashMap<MacVlanPair, OFPort>(MAX_MACS_PER_SWITCH));
		macVlanToSwitchPortMap.put(sw, swMap);
	}
	swMap.put(new MacVlanPair(mac, vlan), portVal);
}
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:22,代碼來源:LearningSwitch.java

示例14: get

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Returns a HashMap<SECONDARY_KEY,HashMap<TERTIARY_KEY,ITEM>>
 * Never returns null, if the map under primary key doesn't exist, an empty one is added and returned.
 * @param primaryKey
 * @return
 */
@SuppressWarnings("unchecked")
@Override
public Map<SECONDARY_KEY, Map<TERTIARY_KEY,ITEM>> get(Object primaryKey)
{
	Map<SECONDARY_KEY, Map<TERTIARY_KEY,ITEM>> result = super.get(primaryKey);
	if (result != null) { return result; };
	result = Collections.synchronizedMap( new HashMapMap<SECONDARY_KEY,TERTIARY_KEY,ITEM>(secondaryCapacity, tertiaryCapacity) );
	super.put( (PRIMARY_KEY)primaryKey,result);
	return result;
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:17,代碼來源:WeakHashTriMap.java

示例15: init

import java.util.Collections; //導入方法依賴的package包/類
private void init(int population, long seed) throws IOException {
  String dbType = Config.get("generate.database_type");

  switch (dbType) {
    case "in-memory":
      this.database = new DataStore(false);
      break;
    case "file":
      this.database = new DataStore(true);
      break;
    case "none":
      this.database = null;
      break;
    default:
      throw new IllegalArgumentException(
          "Unexpected value for config setting generate.database_type: '" + dbType
              + "' . Valid values are file, in-memory, or none.");
  }

  this.numberOfPeople = population;
  this.chws = Collections.synchronizedList(new ArrayList<CommunityHealthWorker>());
  this.seed = seed;
  this.random = new Random(seed);
  this.timestep = Long.parseLong(Config.get("generate.timestep"));
  this.stop = System.currentTimeMillis();
  this.demographics = Demographics.loadByName(Config.get("generate.demographics.default_file"));
  this.logLevel = Config.get("generate.log_patients.detail", "simple");
  this.onlyDeadPatients = Boolean.parseBoolean(Config.get("generate.only_dead_patients"));

  this.totalGeneratedPopulation = new AtomicInteger(0);
  this.stats = Collections.synchronizedMap(new HashMap<String, AtomicInteger>());
  stats.put("alive", new AtomicInteger(0));
  stats.put("dead", new AtomicInteger(0));

  if (Boolean.parseBoolean(
        Config.get("generate.track_detailed_transition_metrics", "false"))) {
    this.metrics = new TransitionMetrics();
  }

  // initialize hospitals
  Hospital.loadHospitals();
  Module.getModules(); // ensure modules load early
  CommunityHealthWorker.workers.size(); // ensure CHWs are set early
  Costs.loadCostData();
}
 
開發者ID:synthetichealth,項目名稱:synthea_java,代碼行數:46,代碼來源:Generator.java


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