本文整理匯總了Java中java.util.concurrent.Semaphore類的典型用法代碼示例。如果您正苦於以下問題:Java Semaphore類的具體用法?Java Semaphore怎麽用?Java Semaphore使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Semaphore類屬於java.util.concurrent包,在下文中一共展示了Semaphore類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: loop
import java.util.concurrent.Semaphore; //導入依賴的package包/類
final int loop(int n) {
final Semaphore sem = this.sem;
int sum = 0;
int x = 0;
while (n-- > 0) {
sem.acquireUninterruptibly();
try {
x = setValue(LoopHelpers.compute1(getValue()));
}
finally {
sem.release();
}
sum += LoopHelpers.compute2(x);
}
return sum;
}
示例2: beforeSend
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Override
protected synchronized void beforeSend(final Object object) {
NetCom2Utils.assertNotNull(object);
if (object.getClass().equals(Acknowledge.class)) {
logging.trace("[TCP] No need to setup an synchronization mechanism an Acknowledge!");
return;
}
logging.trace("[TCP] Locking access to send ..");
communicationLock.lock();
logging.debug("[TCP] Preparing send of " + object + " at Thread " + Thread.currentThread());
final Semaphore semaphore = new Semaphore(1);
logging.trace("[TCP] ClientMapping synchronization mechanism ..");
synchronized (mapping) {
mapping.put(object.getClass(), semaphore);
}
logging.trace("[TCP] Setting up Callback ..");
receivingService.addReceivingCallback(new TCPAckCallback(object.getClass()));
}
示例3: testRemoveListener
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Test
public void testRemoveListener()
throws TestFailure, ExecutionException, TimeoutException, InterruptedException {
DatabaseReference ref = IntegrationTestUtils.getRandomNode(masterApp);
final Semaphore semaphore = new Semaphore(0);
ValueEventListener listener = ref.limitToLast(5)
.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot snapshot) {
semaphore.release();
}
@Override
public void onCancelled(DatabaseError error) {
}
});
ref.setValueAsync(MapBuilder.of("a", 5, "b", 6));
TestHelpers.waitFor(semaphore, 1);
ref.limitToLast(5).removeEventListener(listener);
new WriteFuture(ref, MapBuilder.of("a", 6, "b", 5)).timedGet();
TestHelpers.waitForQueue(ref);
assertEquals(0, semaphore.availablePermits());
}
示例4: testSetPriority
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Test
public void testSetPriority() throws InterruptedException {
final DatabaseReference ref = IntegrationTestUtils.getRandomNode(masterApp);
ref.setValueAsync("hello!");
final Semaphore semaphore = new Semaphore(0);
ref.setPriority(10, new DatabaseReference.CompletionListener() {
@Override
public void onComplete(DatabaseError error, DatabaseReference callbackRef) {
assertEquals(ref, callbackRef);
assertNull(error);
semaphore.release(1);
}
});
assertTrue(semaphore.tryAcquire(1, TestUtils.TEST_TIMEOUT_MILLIS, TimeUnit.MILLISECONDS));
}
示例5: testUpdateAfterSetLeafNodeWorks
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Test
public void testUpdateAfterSetLeafNodeWorks() throws InterruptedException {
DatabaseReference ref = IntegrationTestUtils.getRandomNode(masterApp);
final Semaphore semaphore = new Semaphore(0);
final Map<String, Object> expected = new MapBuilder().put("a", 1L).put("b", 2L).build();
ref.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot snapshot) {
if (DeepEquals.deepEquals(snapshot.getValue(), expected)) {
semaphore.release();
}
}
@Override
public void onCancelled(DatabaseError error) {
}
});
ref.setValueAsync(42);
ref.updateChildrenAsync(expected);
TestHelpers.waitFor(semaphore);
}
示例6: test2
import java.util.concurrent.Semaphore; //導入依賴的package包/類
/**
* @throws Exception
*/
@Test
public void test2() throws Exception {
Semaphore semaphore = new Semaphore(10, true);
for (int i = 0; i < MAX_THREAD_COUNT; i++) {
new MultithreadingTest(i, semaphore, this).start();
if (i > 0 && i % 100 == 0) {
synchronized (this) {
while (counter != i) {
wait();
}
}
}
}
synchronized (this) {
while (counter != MAX_THREAD_COUNT) {
wait();
}
System.out.println("counter: " + counter);
}
}
示例7: getSnap
import java.util.concurrent.Semaphore; //導入依賴的package包/類
public static DataSnapshot getSnap(Query ref) throws InterruptedException {
final Semaphore semaphore = new Semaphore(0);
// Hack to get around final reference issue
final List<DataSnapshot> snapshotList = new ArrayList<>(1);
ref.addListenerForSingleValueEvent(
new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot snapshot) {
snapshotList.add(snapshot);
semaphore.release(1);
}
@Override
public void onCancelled(DatabaseError error) {
semaphore.release(1);
}
});
semaphore.tryAcquire(1, TestUtils.TEST_TIMEOUT_MILLIS, TimeUnit.MILLISECONDS);
return snapshotList.get(0);
}
示例8: release
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@APILevel
void release(RemoteAccessCommunicationResponse response) {
synchronized (responseMap) {
responseMap.put(response.getUuid(), response);
}
Semaphore semaphore = getSemaphore(response.getUuid());
if(semaphore == null) {
return;
}
semaphore.release();
}
示例9: open
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Override
public Point open(SurfaceTexture surface) {
try {
if(!extractMedia()){
return new Point(0,0);
}
mFrameSem=new Semaphore(0);
mDecodeSem=new Semaphore(1);
videoProvideEndFlag=false;
isUserWantToStop=false;
mAudioEncodeTrack=mStore.addTrack(mExtractor.getTrackFormat(mAudioDecodeTrack));
MediaFormat format=mExtractor.getTrackFormat(mVideoDecodeTrack);
mVideoDecoder = MediaCodec.createDecoderByType(format.getString(MediaFormat.KEY_MIME));
mVideoDecoder.configure(format,new Surface(surface),null,0);
mVideoDecoder.start();
startDecodeThread();
} catch (IOException e) {
e.printStackTrace();
}
return mVideoSize;
}
示例10: testRangeMergeUpdate
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Test
public void testRangeMergeUpdate() throws InterruptedException {
final Repo repo = newRepo();
final List<DataSnapshot> events = new ArrayList<>();
QuerySpec spec = new QuerySpec(new Path("/rangeMerge"), QueryParams.DEFAULT_PARAMS);
addCallback(repo, new ValueEventRegistration(repo, newValueEventListener(events), spec));
final Semaphore semaphore = new Semaphore(0);
final RangeMerge merge = new RangeMerge(ImmutableList.of("p1"),
ImmutableList.of("p5"), ImmutableMap.of("p2", "v2", "p3", "v3"));
repo.scheduleNow(new Runnable() {
@Override
public void run() {
repo.onRangeMergeUpdate(
ImmutableList.of("rangeMerge"), ImmutableList.of(merge), null);
semaphore.release();
}
});
waitFor(semaphore);
assertEquals(1, events.size());
assertNotNull(events.get(0));
assertEquals(ImmutableMap.of("p2", "v2", "p3", "v3"), events.get(0).getValue());
}
示例11: testSetValue
import java.util.concurrent.Semaphore; //導入依賴的package包/類
@Test
public void testSetValue() throws InterruptedException {
final Repo repo = newRepo();
final List<DataSnapshot> events = new ArrayList<>();
final Path path = new Path("/foo");
QuerySpec spec = new QuerySpec(path, QueryParams.DEFAULT_PARAMS);
addCallback(repo, new ValueEventRegistration(repo, newValueEventListener(events), spec));
final Semaphore semaphore = new Semaphore(0);
repo.scheduleNow(new Runnable() {
@Override
public void run() {
repo.setValue(path, NodeUtilities.NodeFromJSON("setValue"), null);
semaphore.release();
}
});
waitFor(semaphore);
assertEquals(1, events.size());
assertNotNull(events.get(0));
assertEquals("setValue", events.get(0).getValue(String.class));
}
示例12: processLogic
import java.util.concurrent.Semaphore; //導入依賴的package包/類
private void processLogic(Bundle savedInstanceState) {
this.mSaveImgDir = (File) getIntent().getSerializableExtra(EXTRA_SAVE_IMG_DIR);
if (this.mSaveImgDir == null) {
this.mDownloadIv.setVisibility(4);
}
this.mPreviewImages = getIntent().getStringArrayListExtra(EXTRA_PREVIEW_IMAGES);
this.mIsSinglePreview = getIntent().getBooleanExtra(EXTRA_IS_SINGLE_PREVIEW, false);
if (this.mIsSinglePreview) {
this.mPreviewImages = new ArrayList();
this.mPreviewImages.add(getIntent().getStringExtra(EXTRA_PHOTO_PATH));
}
int currentPosition = getIntent().getIntExtra(EXTRA_CURRENT_POSITION, 0);
this.mContentHvp.setAdapter(new ImagePageAdapter());
this.mContentHvp.setCurrentItem(currentPosition);
renderTitleTv();
this.mSemaphore = new Semaphore(1);
this.mTitleRl.postDelayed(new Runnable() {
public void run() {
MQPhotoPreviewActivity.this.hiddenTitlebar();
}
}, 2000);
}
示例13: MiniConnectionPoolManager
import java.util.concurrent.Semaphore; //導入依賴的package包/類
/**
* Constructs a MiniConnectionPoolManager object.
*
* @param dataSource the data source for the connections.
* @param maxConnections the maximum number of connections.
* @param timeout the maximum time in seconds to wait for a free connection.
*/
public MiniConnectionPoolManager(ConnectionPoolDataSource dataSource, int maxConnections,
int timeout) {
this.dataSource = dataSource;
this.maxConnections = maxConnections;
this.timeoutMs = timeout * 1000L;
try {
logWriter = dataSource.getLogWriter();
} catch (SQLException e) {
}
if (maxConnections < 1) {
throw new IllegalArgumentException("Invalid maxConnections value.");
}
semaphore = new Semaphore(maxConnections, true);
recycledConnections = new LinkedList<PooledConnection>();
poolConnectionEventListener = new PoolConnectionEventListener();
}
示例14: SharedByteArray
import java.util.concurrent.Semaphore; //導入依賴的package包/類
public SharedByteArray(
MemoryTrimmableRegistry memoryTrimmableRegistry,
PoolParams params) {
Preconditions.checkNotNull(memoryTrimmableRegistry);
Preconditions.checkArgument(params.minBucketSize > 0);
Preconditions.checkArgument(params.maxBucketSize >= params.minBucketSize);
mMaxByteArraySize = params.maxBucketSize;
mMinByteArraySize = params.minBucketSize;
mByteArraySoftRef = new OOMSoftReference<byte[]>();
mSemaphore = new Semaphore(1);
mResourceReleaser = new ResourceReleaser<byte[]>() {
@Override
public void release(byte[] unused) {
mSemaphore.release();
}
};
memoryTrimmableRegistry.registerMemoryTrimmable(this);
}
示例15: testSearchScopesNotifiedAboutChangesInEDT
import java.util.concurrent.Semaphore; //導入依賴的package包/類
public void testSearchScopesNotifiedAboutChangesInEDT()
throws InterruptedException {
CustomSearchScope css = new CustomSearchScope(true, 1);
SearchScopeList ssl = new SearchScopeList(css);
final Semaphore s = new Semaphore(0);
final AtomicBoolean notifiedInEDT = new AtomicBoolean(false);
ssl.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
notifiedInEDT.set(EventQueue.isDispatchThread());
s.release();
}
});
css.fireChangeEvent();
boolean acqrd = s.tryAcquire(10, TimeUnit.SECONDS);
assertTrue("Should be notified in EDT", acqrd && notifiedInEDT.get());
}