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


Java Collections.synchronizedSet方法代碼示例

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


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

示例1: startScheduler

import java.util.Collections; //導入方法依賴的package包/類
private void startScheduler(int initialPeriod) {
    if (futureTask != null) {
        futureTask.cancel(true);
    }

    Runnable meshUpdateThread = new Runnable() {
        @Override
        public void run() {
            // Reset the node list
            synchronized (nodesInProgress) {
                nodesInProgress = Collections.synchronizedSet(new HashSet<Integer>());
            }

            // Start discovery from root node.
            startMeshUpdate(0);
        }
    };

    futureTask = scheduler.scheduleAtFixedRate(meshUpdateThread, initialPeriod, updatePeriod, TimeUnit.SECONDS);
}
 
開發者ID:zsmartsystems,項目名稱:com.zsmartsystems.zigbee,代碼行數:21,代碼來源:ZigBeeNetworkMeshMonitor.java

示例2: DelegationTokenToRenew

import java.util.Collections; //導入方法依賴的package包/類
public DelegationTokenToRenew(Collection<ApplicationId> applicationIds,
    Token<?> token,
    Configuration conf, long expirationDate, boolean shouldCancelAtEnd,
    String user) {
  this.token = token;
  this.user = user;
  if (token.getKind().equals(new Text("HDFS_DELEGATION_TOKEN"))) {
    try {
      AbstractDelegationTokenIdentifier identifier =
          (AbstractDelegationTokenIdentifier) token.decodeIdentifier();
      maxDate = identifier.getMaxDate();
    } catch (IOException e) {
      throw new YarnRuntimeException(e);
    }
  }
  this.referringAppIds = Collections.synchronizedSet(
      new HashSet<ApplicationId>(applicationIds));
  this.conf = conf;
  this.expirationDate = expirationDate;
  this.timerTask = null;
  this.shouldCancelAtEnd = shouldCancelAtEnd;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:23,代碼來源:DelegationTokenRenewer.java

示例3: testNotifyOnDisconnectInSniffer

import java.util.Collections; //導入方法依賴的package包/類
public void testNotifyOnDisconnectInSniffer() throws IOException {
    internalCluster().ensureAtLeastNumDataNodes(2);

    final Set<DiscoveryNode> disconnectedNodes = Collections.synchronizedSet(new HashSet<>());
    try (TransportClient client = new MockTransportClient(Settings.builder()
        .put("cluster.name", internalCluster().getClusterName()).build(), Collections.emptySet(), (n, e) -> disconnectedNodes.add(n))) {
        int numNodes = 0;
        for (TransportService service : internalCluster().getInstances(TransportService.class)) {
            numNodes++;
            client.addTransportAddress(service.boundAddress().publishAddress());
        }
        Set<TransportAddress> discoveryNodes = client.connectedNodes().stream().map(n -> n.getAddress()).collect(Collectors.toSet());
        assertEquals(numNodes, discoveryNodes.size());
        assertEquals(0, disconnectedNodes.size());
        internalCluster().stopRandomDataNode();
        client.getNodesService().doSample();
        assertEquals(1, disconnectedNodes.size());
        assertTrue(discoveryNodes.contains(disconnectedNodes.stream().findAny().get().getAddress()));
    }
    assertEquals(1, disconnectedNodes.size());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:22,代碼來源:NodeDisconnectIT.java

示例4: POAFactory

import java.util.Collections; //導入方法依賴的package包/類
/** All object adapter factories must have a no-arg constructor.
*/
public POAFactory()
{
    poaManagers = Collections.synchronizedSet(new HashSet(4));
    poaManagerId = 0 ;
    poaId = 0 ;
    rootPOA = null ;
    delegateImpl = null ;
    orb = null ;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:12,代碼來源:POAFactory.java

示例5: ReplayingState

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Creates new replaying state
 * @param baseUri the base uri for building the whitelisted http urls
 */
@Inject
public ReplayingState(@Named(BASE_URI) URI baseUri) {
    this.synchronizationEventOptional = Optional.empty();
    this.httpLock = false;
    this.httpRequestQueue = Collections.synchronizedSet(new HashSet<>());
    this.conditionsSatisfied = Collections.synchronizedSet(new HashSet<>());
    this.whiteListHttp = buildWhiteList(baseUri);
}
 
開發者ID:hristo-vrigazov,項目名稱:bromium,代碼行數:13,代碼來源:ReplayingState.java

示例6: JCAManagedConnection

import java.util.Collections; //導入方法依賴的package包/類
public JCAManagedConnection(JCAManagedConnectionFactory fact) {
  this.factory = fact;
  this.listeners = Collections
      .<ConnectionEventListener>synchronizedList(new ArrayList<ConnectionEventListener>());
  this.localTran = new JCALocalTransaction();
  this.connections =
      Collections.<GFConnectionImpl>synchronizedSet(new HashSet<GFConnectionImpl>());
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:9,代碼來源:JCAManagedConnection.java

示例7: testFsShutdownHook

import java.util.Collections; //導入方法依賴的package包/類
public void testFsShutdownHook() throws Exception {
  final Set<FileSystem> closed = Collections.synchronizedSet(new HashSet<FileSystem>());
  Configuration conf = new Configuration();
  Configuration confNoAuto = new Configuration();

  conf.setClass("fs.test.impl", TestShutdownFileSystem.class, FileSystem.class);
  confNoAuto.setClass("fs.test.impl", TestShutdownFileSystem.class, FileSystem.class);
  confNoAuto.setBoolean("fs.automatic.close", false);

  TestShutdownFileSystem fsWithAuto =
    (TestShutdownFileSystem)(new Path("test://a/").getFileSystem(conf));
  TestShutdownFileSystem fsWithoutAuto =
    (TestShutdownFileSystem)(new Path("test://b/").getFileSystem(confNoAuto));

  fsWithAuto.setClosedSet(closed);
  fsWithoutAuto.setClosedSet(closed);

  // Different URIs should result in different FS instances
  assertNotSame(fsWithAuto, fsWithoutAuto);

  FileSystem.CACHE.closeAll(true);
  assertEquals(1, closed.size());
  assertTrue(closed.contains(fsWithAuto));

  closed.clear();

  FileSystem.closeAll();
  assertEquals(1, closed.size());
  assertTrue(closed.contains(fsWithoutAuto));
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:31,代碼來源:TestFileSystem.java

示例8: AzurePlayerList

import java.util.Collections; //導入方法依賴的package包/類
private AzurePlayerList() {
    names = Collections.synchronizedSet(AzureAPI.newCaseInsensitiveSet()); // access in AsyncPreLoginEvent
    players = Lists.newArrayListWithExpectedSize(Bukkit.getMaxPlayers());
    
    join = Lists.newArrayList();
    quit = Lists.newArrayList();
    
    for (World world : Bukkit.getWorlds()) {
        for (Player each : world.getPlayers()) {
            names.add(each.getName());
            players.add(each);
        }
    }
}
 
開發者ID:GelandiAssociation,項目名稱:EscapeLag,代碼行數:15,代碼來源:AzurePlayerList.java

示例9: LRUCacheMap

import java.util.Collections; //導入方法依賴的package包/類
public LRUCacheMap(int size, long timeToLiveInMillis, long maxIdleInMillis) {
    super(size, timeToLiveInMillis, maxIdleInMillis);
    
    for (int i = 0; i < Runtime.getRuntime().availableProcessors()*2; i++) {
        Set<CachedValue<K, V>> instance = Collections.synchronizedSet(new LinkedHashSet<CachedValue<K, V>>());
        queues.add(instance);
    }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:9,代碼來源:LRUCacheMap.java

示例10: validGroupSinks

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Check availability of sinks for group
 *
 * @param sinkSet
 *          [in]Existing valid sinks
 * @param usedSinks
 *          [in/out]Sinks already in use by other groups
 * @param groupConf
 *          [in]sinkgroup configuration
 * @return List of sinks available and reserved for group
 */
private Set<String> validGroupSinks(Set<String> sinkSet,
                                    Map<String, String> usedSinks,
                                    SinkGroupConfiguration groupConf) {
  Set<String> groupSinks =
      Collections.synchronizedSet(new HashSet<String>(groupConf.getSinks()));

  if (groupSinks.isEmpty()) return null;
  Iterator<String> sinkIt = groupSinks.iterator();
  while (sinkIt.hasNext()) {
    String curSink = sinkIt.next();
    if (usedSinks.containsKey(curSink)) {
      logger.warn("Agent configuration for '" + agentName + "' sinkgroup '"
          + groupConf.getComponentName() + "' sink '" + curSink
          + "' in use by " + "another group: '" + usedSinks.get(curSink)
          + "', sink not added");
      errorList.add(new FlumeConfigurationError(agentName, groupConf
          .getComponentName(),
          FlumeConfigurationErrorType.PROPERTY_PART_OF_ANOTHER_GROUP,
          ErrorOrWarning.ERROR));
      sinkIt.remove();
      continue;
    } else if (!sinkSet.contains(curSink)) {
      logger.warn("Agent configuration for '" + agentName + "' sinkgroup '"
          + groupConf.getComponentName() + "' sink not found: '" + curSink
          + "',  sink not added");
      errorList.add(new FlumeConfigurationError(agentName, curSink,
          FlumeConfigurationErrorType.INVALID_PROPERTY,
          ErrorOrWarning.ERROR));
      sinkIt.remove();
      continue;
    } else {
      usedSinks.put(curSink, groupConf.getComponentName());
    }
  }
  return groupSinks;
}
 
開發者ID:moueimei,項目名稱:flume-release-1.7.0,代碼行數:48,代碼來源:FlumeConfiguration.java

示例11: multipleInstancesTest

import java.util.Collections; //導入方法依賴的package包/類
@Test
public void multipleInstancesTest() throws InterruptedException {
    final Set<String> ids = Collections.synchronizedSet(new HashSet<String>());
    final int threadCount = 20;
    final int iterationCount = 10000;
    final CountDownLatch latch = new CountDownLatch(threadCount);

    for (int i = 0; i < threadCount; i++) {
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                IDGenerator generator = LocalUniqueIDGeneratorFactory.generatorFor(1, 1);
                try {
                    for (int i = 0; i < iterationCount; i++) {
                        byte[] id = generator.generate();
                        String asHex = Hex.encodeHexString(id);
                        ids.add(asHex);
                    }
                } catch (GeneratorException e) {
                    e.printStackTrace();
                }
                latch.countDown();
            }
        });
        t.start();
    }

    boolean successfullyUnlatched = latch.await(20, TimeUnit.SECONDS);
    assertThat(successfullyUnlatched, is(true));

    assertThat(ids.size(), is(threadCount * iterationCount));
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:33,代碼來源:UniqueIDGeneratorThreadSafetyIT.java

示例12: moreThanOneGeneratorClusterIDTest

import java.util.Collections; //導入方法依賴的package包/類
@Test
public void moreThanOneGeneratorClusterIDTest() throws InterruptedException {
    final Set<String> ids = Collections.synchronizedSet(new HashSet<String>());
    final int[][] profiles = { { 0, 0 }, { 1, 1 }, { 1, 2 }, { 1, 3 }, { 1, 15 }, { 2, 0 },
                               { 3, 0 }, { 4, 0 }, { 5, 0 }, { 63, 0 } };
    final int iterationCount = 10000;
    final CountDownLatch latch = new CountDownLatch(profiles.length);

    for (final int[] profile : profiles) {
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                IDGenerator generator = LocalUniqueIDGeneratorFactory.generatorFor(profile[0],
                    profile[1]);
                try {
                    for (int i = 0; i < iterationCount; i++) {
                        byte[] id = generator.generate();
                        String asHex = Hex.encodeHexString(id);
                        ids.add(asHex);
                    }
                } catch (GeneratorException e) {
                    e.printStackTrace();
                }
                latch.countDown();
            }
        });
        t.start();
    }

    boolean successfullyUnlatched = latch.await(20, TimeUnit.SECONDS);
    assertThat(successfullyUnlatched, is(true));

    assertThat(ids.size(), is(profiles.length * iterationCount));
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:35,代碼來源:UniqueIDGeneratorThreadSafetyIT.java

示例13: init

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Initialize the cache, providing all parameters.
 * 
 * @param cacheParams
 *            The cache parameters to initialize the cache
 */
private void init(ImageCacheParams cacheParams) {
	ImageCacheParams mCacheParams = cacheParams;

	// BEGIN_INCLUDE(init_memory_cache)
	// Set up memory cache
	if (mCacheParams.memoryCacheEnabled) {
		if (BuildConfig.DEBUG) {
			Log.d(TAG, "Memory cache created (size = "
					+ mCacheParams.memCacheSize + ")");
		}

		// If we're running on Honeycomb or newer, create a set of reusable
		// bitmaps that can be
		// populated into the inBitmap field of BitmapFactory.Options. Note
		// that the set is
		// of SoftReferences which will actually not be very effective due
		// to the garbage
		// collector being aggressive clearing Soft/WeakReferences. A better
		// approach
		// would be to use a strongly references bitmaps, however this would
		// require some
		// balancing of memory usage between this set and the bitmap
		// LruCache. It would also
		// require knowledge of the expected size of the bitmaps. From
		// Honeycomb to JellyBean
		// the size would need to be precise, from KitKat onward the size
		// would just need to
		// be the upper bound (due to changes in how inBitmap can re-use
		// bitmaps).
		if (Utils.hasHoneycomb()) {
			mReusableBitmaps = Collections
					.synchronizedSet(new HashSet<SoftReference<Bitmap>>());
		}

		mMemoryCache = new LruCache<String, BitmapDrawable>(
				mCacheParams.memCacheSize) {

			/**
			 * Notify the removed entry that is no longer being cached
			 */
			@Override
			protected void entryRemoved(boolean evicted, String key,
					BitmapDrawable oldValue, BitmapDrawable newValue) {
				if (RecyclingBitmapDrawable.class.isInstance(oldValue)) {
					// The removed entry is a recycling drawable, so notify
					// it
					// that it has been removed from the memory cache
					((RecyclingBitmapDrawable) oldValue).setIsCached(false);
				} else {
					// The removed entry is a standard BitmapDrawable

					if (Utils.hasHoneycomb()) {
						// We're running on Honeycomb or later, so add the
						// bitmap
						// to a SoftReference set for possible use with
						// inBitmap later
						mReusableBitmaps.add(new SoftReference<Bitmap>(
								oldValue.getBitmap()));
					}
				}
			}

			/**
			 * Measure item size in kilobytes rather than units which is
			 * more practical for a bitmap cache
			 */
			@Override
			protected int sizeOf(String key, BitmapDrawable value) {
				final int bitmapSize = getBitmapSize(value) / 1024;
				return bitmapSize == 0 ? 1 : bitmapSize;
			}
		};
	}

}
 
開發者ID:mangestudio,項目名稱:GCSApp,代碼行數:82,代碼來源:ImageCache.java

示例14: Subject

import java.util.Collections; //導入方法依賴的package包/類
public Subject(Set<? extends Principal> principals) {
    this.principals = Collections.synchronizedSet(new SecureSet<Principal>
            (this, PRINCIPAL_SET, principals));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:5,代碼來源:Subject.java

示例15: getAnotherObject

import java.util.Collections; //導入方法依賴的package包/類
protected Set<String> getAnotherObject() {
    Set<String> set = Collections.emptySet();
    return Collections.synchronizedSet(set);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:5,代碼來源:java_util_Collections_SynchronizedSet.java


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